inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-A

3-A 질문드립니다!

47

이정재

작성한 질문수 9

0

안녕하세요 문제를 풀었는데 오답이 나와서 질문드려요
http://boj.kr/2cfae2c4629946ce8da516639d668b86
추가로 987654321 로 정하신 것도 그냥 크게 정하신거 같은데 혹시 정확한 범위 알 수 있을까요 ?

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 정재님 ㅎㅎ

가장 먼저 틀린 부분은 이부분입니다. 배열을 좀 더 크게 해보시겠어요? 50까지니까 51까지의 인덱스는 필요합니다.


int n, m, a[54][54];
	if (idx == n+1) {
		if(v.size() == m && check)
		close();
		return;
	}

또한... 리뷰를 드리면..

지금 보시면 인덱스를 1부터 시작해서 나중에 -1를 하는 로직인데요

권장드리는 부분은 idx = 0부터 시작해서...

먼저 idx를 매개변수로 넣어서 push, pop로직을 수행한다면 n - 1이 최대입니다. 즉, idx == n + 1이 아니라 n이 최대로 하는 것.

void go(int idx, int n, bool check) {

그리고 check는 불필요해 보입니다.

go(idx + 1, v)

v.push_back

go(idx + 1, v)

v.pop_back

이런식으로 하는게 좋습니다.

 

dis = min(dis, abs(chicken[v[i] -1].first - home[j].first) + abs(chicken[v[i] -1].second - home[j].second));

여기서도 v[i]로 해야 합니다.

 

또한, 현재 보시면 2^M으로 순열을 기반으로 하는 로직이 있는데 이부분을 조합으로 바꾸는 것이 더 좋습니다.

 

추가로 987654321 로 정하신 것도
-> 이부분은 교안내에 다음부분에 설명되어있습니다. 참고부탁드립니다.

스크린샷 2025-06-07 오후 6.42.40.png.webp

 

 


 

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

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

감사합니다.

강사 큰돌 올림.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 이정재님!

문제 해결에 어려움을 겪고 계신 점 이해합니다. 이진 탐색의 범위 설정과 관련하여 몇 가지 고려할 사항을 안내해 드리겠습니다.

먼저, 문제를 해결하는 과정에서 상한값(hi)을 큰 수로 설정하는 이유는 최악의 경우까지 고려하기 위함입니다. 이는 이진 탐색의 특성상 최악의 경우를 미리 상정하여 범위를 설정해야 탐색의 오류를 줄일 수 있습니다. 하지만 너무 비현실적인 큰 값으로 설정하면 비효율적일 수 있으므로, 문제의 제약 조건이나 입력 범위를 고려하여 합리적인 범위 내에서 설정하는 것이 좋습니다.

문제와 유사한 질문에 대한 링크를 공유드리겠습니다. 참고하시면 더 도움이 될 것 같습니다.

  • 6236번 질문있습니다!: 이 포스트에서는 이진 탐색에서 상한값 설정에 관한 설명이 포함되어 있어 문제 해결의 실마리를 제공할 수 있습니다.

올바른 상한값을 설정하는 것은 문제의 최대 입력값을 고려하여 계산하는 것이 중요합니다. 코드에 따라 다를 수 있지만, 대체로 987654321은 충분한 상한값으로 사용될 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

2주차 개념#12 트리 순회

0

14

2

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

0

214

2

백준 서비스 종료

9

680

1

sk 하이닉스 코테 대비

0

350

2

3-G 최댓값 질문

0

47

1

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

0

81

2

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

0

60

2

3-N 질문 있습니다.

0

64

2

학습방법

0

99

2

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

0

66

2

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

0

163

2

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

0

69

2

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

0

63

2

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

0

48

2

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

0

67

2

함수별 시간복잡도

0

71

2

3-h 질문입니다.

0

48

1

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

0

51

2

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

0

75

2

2-P 질문입니다.

0

56

1

mac에서 시작하기 관련

0

86

2

5-Q 질문

0

62

2

풀이 코드 질문

0

62

2

맞왜틀

0

68

2