3-O 사다리조작문제 질문합니다.
http://boj.kr/32b3838d8d234c319135354effb7f937
안녕하세요. 사다리 조작 문제를 푸는데 거의 다 푼거 같은데 계속 틀려서 .. 도와주세요...
답변 2
0
안녕하세요 정재님 ㅎㅎ
최대한 정재님 스타일로 코드를 다듬어봤습니다.
#include <bits/stdc++.h>
using namespace std;
int N, M, H;
int visited[30][10];
int ret = INT_MAX;
bool ladder() {
for (int start = 0; start < N; start++) {
int pos = start;
for (int h = 0; h < H; h++) {
if (pos < N-1 && visited[h][pos])
pos++;
else if (pos > 0 && visited[h][pos-1])
pos--;
}
if (pos != start) return false;
}
return true;
}
void dfs(int startRow, int startCol, int cnt) {
if (cnt >= ret) return;
if (ladder()) {
ret = cnt;
return;
}
if (cnt == 3) return;
for (int i = startRow; i < H; i++) {
for (int j = (i == startRow ? startCol : 0); j < N-1; j++) {
if (visited[i][j] ||
(j > 0 && visited[i][j-1]) ||
(j < N-2 && visited[i][j+1])) continue;
visited[i][j] = 1;
dfs(i, j + 2, cnt + 1);
visited[i][j] = 0;
}
}
}
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
cin >> N >> M >> H;
for (int i = 0; i < M; i++) {
int a, b;
cin >> a >> b;
visited[a-1][b-1] = 1;
}
dfs(0, 0, 0);
cout << (ret <= 3 ? ret : -1) << "\n";
return 0;
}
새행부터는 0부터 탐색, 연속해서 사다리 놓치 못하게하는 것, 가지치기 이 3개를 중점으로만 봐주시면 됩니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
안녕하세요, 인프런 AI 인턴입니다. 이정재님. 사다리 조작 문제 해결 관련해서 반복적으로 “틀렸습니다” 결과를 받으셨다고 하셨네요. 이 문제에서는 보통 사다리의 설정과 방향성이 중요한데, 틀린 이유는 사다리를 추가하거나 이동시키는 로직에서 발생할 수 있습니다.
다음은 사다리 조작 문제와 관련된 이전 답변들이며, 참고하실 만한 내용들로 도움을 드릴 수 있을 것 같습니다:
-
- 기본적인 로직의 순환과 재귀 구조 확인에 도움이 될 수 있는 내용입니다.
- 기본적인 로직의 순환과 재귀 구조 확인에 도움이 될 수 있는 내용입니다.
-
- 적절한 사다리 추가 로직과 확인 조건 설정에 대한 팁을 얻을 수 있습니다.
- 적절한 사다리 추가 로직과 확인 조건 설정에 대한 팁을 얻을 수 있습니다.
-
- 시간 초과를 해결하기 위한 최적화 방법에 대한 논의가 포함되어 있습니다.
- 시간 초과를 해결하기 위한 최적화 방법에 대한 논의가 포함되어 있습니다.
주요 포인트로 살펴보아야 할 부분은 다음과 같습니다:
- 사다리가 추가될 수 있는 위치가 올바른지, 즉 양 옆이나 위/아래 제한에 걸리지 않는지 확인해야 합니다.
- 재귀 함수나 DFS를 사용할 때, 사다리를 놓는 경우와 놓지 않는 경우 모두 탐색해야 하지만 중복되지 않도록 해야 합니다.
- 최적의 경로를 찾기 위해 가능한 모든 경우의 수를 탐색하지만, 제한 사항으로 인해 만약 3보다 많은 사다리를 놓아야 할 경우에는 -1을 반환해야 합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
2주차 개념#12 트리 순회
0
3
1
백준사이트가 종료된다고 합니다.
0
198
2
백준 서비스 종료
9
625
1
sk 하이닉스 코테 대비
0
345
2
3-G 최댓값 질문
0
45
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
77
2
3-I 코드 질문드립니다.
0
59
2
3-N 질문 있습니다.
0
63
2
학습방법
0
98
2
4-H 질문 있습니다 (코드 리뷰)
0
65
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
161
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
68
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
62
2
1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.
0
48
2
조합 재귀 풀이 확인 해주시면 감사하겠습니다.
0
66
2
함수별 시간복잡도
0
71
2
3-h 질문입니다.
0
47
1
안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.
0
51
2
1-I 문제 질문 드립니다.
0
74
2
2-P 질문입니다.
0
55
1
mac에서 시작하기 관련
0
86
2
5-Q 질문
0
61
2
풀이 코드 질문
0
62
2
맞왜틀
0
67
2





