inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6-I

6-I 질문드립니다 :)

해결된 질문

97

한유태

작성한 질문수 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점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

코딩살구클럽 문의

0

6

1

코딩살구클럽 승인

0

18

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

27

2

3-F 채점 관련 질문

0

23

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

28

2

코딩살구클럽 승인

0

41

2

코딩살구클럽승인

0

33

3

코딩살구클럽 승인

0

48

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

43

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

53

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

61

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

64

2

코딩살구클럽 로그인문제

0

78

3

코딩 살구 클럽 로그인 문제

0

82

2

2-J 채점관련 질문

0

65

3

코딩 살구 클럽 Python 지원 가능 여부

0

77

1

살구클럽 아이디 없음 문제

0

76

1

1-O 코딩살구클럽 채점관련 질문

0

60

2

히든 테스트 케이스가 사라졌습니다

0

57

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

74

2