3-J 질문
208
작성한 질문수 9
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요. 강의를 듣고 아래 코드처럼 다시 한번 풀어봤습니다.main함수 안에서 풀었을 때는 통과가 되었는데 bfs를 밖으로 빼서 풀었더니 틀리게 되었습니다.틀린 원인이 bfs를 밖으로 빼서 그런건지 아니면 제가 확인하지 못한 로직이 문제가 있는지 모르겠습니다. #include <bits/stdc++.h>
using namespace std;
#define y1 aaaa
int n, m, x1, y1, x2, y2, visited[304][304], cnt;
char a[304][304];
string s;
const int dy[] = {-1, 0, 1, 0};
const int dx[] = {0, 1, 0, -1};
void bfs(int sy, int sx, int ey, int ex){
visited[sy][sx] = 1;
queue<int> q;
q.push(1000*sy + sx);
while(a[ey][ex] != '0'){
cnt++;
queue<int> temp;
while(q.size()){
int y = q.front()/1000;
int x = q.front()%1000;
q.pop();
for(int i=0; i<4; i++){
int ny = y+dy[i];
int nx = x+dx[i];
if(ny<0 || ny>=n || nx<0 || nx>=m || visited[ny][nx]) continue;
visited[ny][nx] = cnt;
if(a[ny][nx] == '0'){
//0을 만나면 q에 0이 없을때까지 계속 돈다.
q.push(1000*ny + nx);
} else{
//1이나 목적지#을 만나면 0으로 바꾸고 그 위치를 temp에 기억해둔다.
a[ny][nx] = '0';
temp.push(1000*ny + nx);
}
}
}
//q에 0이 없어지면 temp에 저장해두었던 1의 위치들을 q에 다시 넣어서
//0에서 했던 과정들을 다시 반복해준다.
q = temp;
}
}
int main(){
ios_base::sync_with_stdio(false);
cin.tie(NULL); cout.tie(NULL);
cin >> n >> m;
cin >> x1 >> y1 >> x2 >> y2;
x1--, y1--, x2--, y2--;
for(int i=0; i<n; i++){
for(int j=0; j<m; j++){
cin >> a[i][j];
}
}
bfs(y1, x1, y2, x2);
cout << visited[y2][x2] << '\n';
return 0;
}
답변 1
4 - A
0
8
1
코딩살구클럽 입장이 안됩니다
0
47
2
4-F 경우의 수 질문입니다.
0
30
2
코딩살구클럽 가입이 안됩니다.
0
63
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
52
1
교안 158페이지 문의드립니다
0
43
2
코딩살구클럽 관련 건의사항
0
105
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
44
1
진행 방법 질문드립니다!
0
78
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
63
2
2주차 개념#12 트리 순회
0
32
2
백준사이트가 종료된다고 합니다.
0
307
2
백준 서비스 종료
9
943
1
sk 하이닉스 코테 대비
0
382
2
3-G 최댓값 질문
0
53
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
63
2
3-N 질문 있습니다.
0
68
2
학습방법
0
105
2
4-H 질문 있습니다 (코드 리뷰)
0
68
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
179
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
71
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
65
2
1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.
0
52
2





