2-A 맞왜틀
269
작성한 질문수 9
안녕하세요 강사님 2-A 맞왜틀 원인을 알고싶습니다!
http://boj.kr/7829432fbf3947d7a15bad0490d056d6
답변 1
0
안녕하세요 은진님ㅎㅎ
}
cout << visited[y][x]; // 마지막 pop 직전 최종 값(최단거리값)이 담긴게 y, x 이 부분이요. 마지막에 탐색한지점 y, x가 최종지점인게 자명한가요?
이런식으로 되어야 하지 않을까요?
cout << visited[n-1][m-1];
자 반례입니다.
예제 4번이 통과가 되지 않습니다.
7 7
1011111
1110001
1000001
1000001
1000001
1000001
1111111답 : 13 / 은진님 코드 : 14
Y, X를 디버깅하는 코드를 넣어봤는데 참고 부탁드려요 ㅎㅎ
#include<bits/stdc++.h>
using namespace std;
int n, m, a[104][104], visited[104][104], y, x, cnt; // n, m 둘다 2~100 범위
int dy[4] = {-1, 0, 1, 0};
int dx[4] = {0, 1, 0, -1};
int main(){
cin >> n >> m;
for(int i=0; i<n; i++){
for(int j=0; j<m; j++){
scanf("%1d", &a[i][j]); // 따닥따닥 붙어있는거 입력받는 방법! (cin으로 하니까 안됨)
}
}
queue<pair<int, int>> q; // 이 문제는 yx좌표가 주어지기때문에 pair로 q를 정의함
visited[0][0] = 1;
q.push({0, 0});
while(q.size()){ // q가 빌때까지 while 반복
tie(y, x) = q.front(); // tie로 y, x에 좌표 저장해줘야 계속 시작점을 갱신할 수 있음
cout << y << " : " << x << '\n';
q.pop(); // 저장하고나면 q를 비워버리기 때문!
for(int i=0; i<4; i++){
int ny = y + dy[i]; // ny, nx는 반복될때마다 초기화돼야하므로 지역변수로!
int nx = x + dx[i];
if(ny<0 || nx<0 || ny>=n || nx>=m) continue;
if(a[ny][nx] == 1 && visited[ny][nx] == 0){
visited[ny][nx] = visited[y][x] + 1; // 이렇게 해야 이전 경로에서 1씩 누적되면서 최단거리 구할 수 있음
q.push({ny, nx});
}
}
}
cout << visited[y][x]; // 마지막 pop 직전 최종 값(최단거리값)이 담긴게 y, x
return 0;
}
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제가 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
5-B
0
15
2
4 - A
0
33
2
코딩살구클럽 입장이 안됩니다
0
82
2
4-F 경우의 수 질문입니다.
0
35
2
코딩살구클럽 가입이 안됩니다.
0
85
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
63
1
교안 158페이지 문의드립니다
0
46
2
코딩살구클럽 관련 건의사항
0
119
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
45
1
진행 방법 질문드립니다!
0
83
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
64
2
2주차 개념#12 트리 순회
0
33
2
백준사이트가 종료된다고 합니다.
0
318
2
백준 서비스 종료
9
953
1
sk 하이닉스 코테 대비
0
388
2
3-G 최댓값 질문
0
54
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
66
2
3-N 질문 있습니다.
0
68
2
학습방법
0
105
2
4-H 질문 있습니다 (코드 리뷰)
0
69
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
186
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
74
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
66
2





