inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

4-B 정답코드에 대해 잘 이해가 안 됩니다.

240

동글

작성한 질문수 1

0

https://www.acmicpc.net/source/share/c19e6a890efe4edcb2a98fedca33b37b

안녕하세요. 4-b가 어려워 강의를 들었는데도 답지코드도 이해가 안되는 부분이 있어서 질문드립니다.

 

16번째 라인에

sum += min(cnt, n - cnt);

해당 부분이 이해가 잘 안 됩니다.

 

cnt를 구하는 부분이나 n-cnt를 하는 부분은 열을 뒤집을지 말지를 결정하기 위해 필요한 값이라는 것은 알고 있습니다. 하지만 min(cnt, n-cnt)를 구하여 열을 뒤집을지말지를 결정해서 연산+1 을 하는 것이 아니라, 더한다는 의미가 어떤 것인지 잘 이해가 안 갑니다.

또한 행을 뒤집으면 최적해가 이미 정해졌다는 것까지는 강의를 듣고 어렴풋이 알 것 같은데,

행을 뒤집는 연산에 대한 +1은 하지 않는지도 궁금합니다. (행을 두개 뒤집는다든지, 한 개 뒤집는다든지,, 등)

 

min(cnt, n-cnt)를 더하는 것이 행과 열의 연산을 모두 포함하는 것 같기도 한데 원리(?)에 대해 이해하기가 어렵습니다. 도와주세요!!

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 동글님 ㅎㅎ

행을 뒤집는 연산에 대한 +1은 하지 않는지도 궁금합니다.

>> 애초에 그 연산에 대한 + 1은 중요하지 않습니다. 문제를 잠시 볼까요?

첫째 줄에 한 행 또는 한 열에 놓인 N개의 동전을 모두 뒤집는 작업들을 수행하여 뒷면이 위를 향하여 놓일 수 있는 동전의 최소 개수를 출력한다.

어떻게든 최소화 시키는게 이 문제의 핵심이죠?

 

min(cnt, n-cnt)를 더하는 것이 행과 열의 연산을 모두 포함하는 것 같기도 한데 원리(?)에 대해 이해하기

>> 자 우리가 마지막 기저사례까지 왔다고 칠게요.

void go(int here){
	if(here == n + 1){
		int sum = 0; 
		for(int i = 1; i <= (1 << (n - 1)); i *= 2){
			int cnt = 0; 
			for(int j = 1; j <= n; j++) if(a[j] & i)cnt++;
			sum += min(cnt, n - cnt); 
		}

here == n + 1인 상태입니다.

동전이 뒤집어진 것을 보니까.

ooooxxxooo 이렇게 뒤집어져있어요. o가 뒷면이죠.

뒷면 : 7개 / 앞면 3개

 

이상태에서 이 행 자체를 한번 더 뒤집어서

뒷면 : 3개 / 앞면 7개

를 만들어 뒷면을 최소화해서 3개로 만드는게 최적해지 않을까요?

그부분이 담긴 코드가 바로.

sum += min(cnt, n - cnt);

입니다.



또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


0

동글

아 문제를 잘못 이해하고 있어서 연산의 개수도 최소화라고 이해했네요ㅜㅜ 이미 최적해라고 가정된 상태라서 sum에 더할 수 있었더군요!! 답변 감사합니다

코딩살구클럽 관련 건의사항

0

4

0

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

4

0

진행 방법 질문드립니다!

0

32

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

55

2

2주차 개념#12 트리 순회

0

25

2

백준사이트가 종료된다고 합니다.

0

284

2

백준 서비스 종료

9

883

1

sk 하이닉스 코테 대비

0

367

2

3-G 최댓값 질문

0

50

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

83

2

3-I 코드 질문드립니다.

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

102

2

4-H 질문 있습니다 (코드 리뷰)

0

66

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

169

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

69

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

64

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

51

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

68

2

함수별 시간복잡도

0

73

2

3-h 질문입니다.

0

49

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

53

2

1-I 문제 질문 드립니다.

0

76

2

2-P 질문입니다.

0

56

1