15684 사다리조작 로직 틀린이유 질문드립니다
285
박완섭
작성한 질문수 15
0
http://boj.kr/86f590d9ef414ae4ae1036cfc127461a
로직이 어디서 잘못됐는지 모르겠습니다.
혹시 어디에서 제가 잘못 작성했을까요..?
답변 1
0
안녕하세요 완섭님 ㅎㅎ
지금 이 코드 실행해봤는데요.
예제 7번 입력했을 때 2가 아니라 -1이 뜨는데 확인해보시겠어요?
또한 주석 달았으니 확인 부탁드립니다.
#include <bits/stdc++.h>
using namespace std;
int n, m, h;
int sadari[40][15];
bool visited[40][15];
int ans = 987654321;
bool check() {
// good
for (int j = 1; j <= n; j++) {
int num = j;
for (int i = 1; i <= h; i++) {
if (sadari[i][num]) num++;
else if (sadari[i][num - 1]) num--;
}
if (num != j) return false;
}
return true;
}
void go(int row, int col, int num, int level) {
// good
if (num > 3 || num >= ans) { return; }
if (check()) {
ans = min(ans, num);
return;
}
// 이거요. 왜 i는 1부터 시작하시나요?
// 이렇게 하면 재귀함수를 돌려도 계속해서 go(1, 1) 부터 확인해나가며 비효율적
// (물론 visited로 거르겠지만) 이지 않을까요?
for (int i = 1; i <= h; i++) {
for (int j = 1; j < n; j++) {
if (sadari[i][j]||visited[i][j]) continue;
visited[i][j] = true;
go(i, j, num, level+1);
if (!(sadari[i][j - 1] || sadari[i][j + 1])) {
sadari[i][j] = 1;
go(i, j, num + 1, level+1);
sadari[i][j] = 0;
}
}
}
}
int main(void)
{
cin >> n >> m >> h;
for (int i = 0; i < m; i++) {
int a, b;
cin >> a >> b;
sadari[a][b] = 1;
}
visited[1][1] = true;
go(1, 1, 0, 1);
if (!sadari[1][1] && !sadari[1][2]) {
sadari[1][1] = 1;
go(1, 1, 1, 1);
sadari[1][1] = 0;
}
if (ans > 3) cout << -1;
else cout << ans;
}
또 질문 있으시면 언제든지 질문 부탁드립니다.
감사합니다.
강사 큰돌 올림.
1-E질문입니다!
0
508
2
3-L 틀린 부분 피드백 부탁드립니다.
0
811
2
1-A문제 순열재귀함수 질문입니다.
0
376
1
1-A 일곱난쟁이문제입니다
0
451
1
문제 풀 때 방향성에 대해
0
793
1
맥에서 vs code로 실행 관련 질문입니다
0
515
1
17071번 메모리 초과
0
381
1
1-C질문입니다!
0
411
2
2-B BFS 시간초과질문
0
622
2
1-O 13번 라인
0
434
1
6-J 놀이공원 문제 질문
0
375
1
구현관련 질문
0
478
1
강의 교안
0
313
1
실력을 더 올리고나서 강의를 보는 것이 맞을까요?
0
540
1
안녕하세요! 재귀함수에 관해서 질문드립니다
0
531
1
1-K
0
468
2
3-G번 질문있습니다.
1
464
3
3-C 실행 시간 질문드립니다.
0
489
1
4-A 문제 풀이 질문있습니다.
0
586
2
비트마스킹 연산자 "1의 보수" 영문 표기법
0
430
1
격자탐색 문제에서 BFS 시간복잡도 질문드립니다.
0
329
1
3-O go 함수 질문 드립니다.
1
437
2
4-A 출력 질문
0
298
1
1주차 1-O 질문드립니다
0
250
1





