inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6-I

6-I 질문드립니다 :)

해결된 질문

95

한유태

작성한 질문수 79

0

안녕하세요 선생님 🙂

이번 문제도 테스트케이스는 맞췄는데 틀렸네요 ㅠㅠ

 

이번 문제는 모르는 부분이 좀 많습니다!

 

  1. high의 값을 입력된 배열의 최소값으로 설정하였습니다. 왜 틀리는걸까요?

테스트케이스에서 파의 길이 중에 가장 짧은 길이는 230입니다. 230보다 긴 파는 있을 수 없다고 판단하여 변수에 값을 저장한 후에 high의 값을 지정하였습니다.

 

  1. Check함수의 조건의 순서에 따라 값이 묘하게 바뀝니다.

// main
if (Check(mid))
{
	high = mid - 1;
	result = mid;
}
else
{
	low = mid + 1;
}


bool Check(ll m)
{
	return cnt < C;
}

그동안은 위와 같이 조건을 세웠었는데요, 이번 문제는 high와 low의 값을 변경해주는 위치가 바뀌었습니다. 그에 따라 Check함수의 return 조건도 아래와 같이 정반대로 바뀌었습니다. 윗 코드대로 출력을 하면 mid의 값이 176이 나옵니다. 반대로 아래 코드대로 출력하면 mid의 값은 175가 나옵니다.

// main
if (Check(mid))
{
	low = mid + 1;
	result = mid;
}
else
{
	high = mid - 1;
}


bool Check(ll m)
{
	return cnt >= C;
}

아무리 봐도 두 코드는 같은 코드로 보이는데요, 왜 값이 차이가 나는건지 모르겠습니다. 또, 이번 문제는 왜 아래의 방식을 선택하셨는지도 궁금합니다.

 

  1. 저는 아래의 링크와 같이 Check함수에서 result의 값을 도출하여 출력을 하였습니다.

     

아무리봐도 문제가 없다고 생각하는데요, 이렇게 풀이하면 왜 틀리는걸까요?

http://boj.kr/325f8cd992f24dbbabf49c86a12384f6

c++ 코딩-테스트

답변 1

1

큰돌

안녕하세요 유태님 ㅎㅎ

		if(check(mid)){
			lo = mid + 1; 
			ret = mid;
		}else hi = mid - 1;

이상인 걸 찾으면 -> 반으로 줄이는데 lo를 mid + 1을 해서 더 큰 방향으로 줄여야 합니다.

또 파닭 맛은 파의 양에 따라 좌우된다고 생각하기 때문에 될 수 있는 한 파의 양을 최대한 많이 넣으려고 한다.

문제지문을 보시면 최대한 많은 양이기 때문에 충족시킨다 -> 더 많은양의 파를 찾게 서칭해야 합니다.

 

  1. high의 값을 입력된 배열의 최소값으로 설정하였습니다. 왜 틀리는걸까요? >> min으로 하게 되면 다음의 반례를 해결하지 못합니다.

2 5 100 1000

100

이 때는 200을 기반으로 파를 써야하는데 min으로 하게 되면 최대 100으로 밖에 못나누게 되고 -> 로직상 에러가 생깁니다.


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

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

감사합니다.

강사 큰돌 올림.

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

0

41

2

2주차 개념#12 트리 순회

0

22

2

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

0

266

2

백준 서비스 종료

9

842

1

sk 하이닉스 코테 대비

0

366

2

3-G 최댓값 질문

0

50

1

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

0

82

2

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

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

101

2

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

0

66

2

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

0

167

2

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

0

69

2

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

0

64

2

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

0

50

2

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

0

67

2

함수별 시간복잡도

0

72

2

3-h 질문입니다.

0

49

1

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

0

53

2

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

0

76

2

2-P 질문입니다.

0

56

1

mac에서 시작하기 관련

0

91

2

5-Q 질문

0

63

2

풀이 코드 질문

0

64

2