당근마킷 엔지니어 승원이 예제에 대한 질문입니다
555
작성한 질문수 23
안녕하세요 강사님
승원이 예제를 풀다가 궁금한 것이 있어 질문드립니다.
승원이의 위치(y, x)를 (sy, sx)로 선언하셨고 문제에서 승원이 위치에서 출발한다고 했기 때문에
시작위치는 (sy, sx)이고, 그렇기 때문에 queue에 q.push({sy, sx})를 한 것은 이해가 되었습니다.
그 다음 q.front()를 통해 큐에 있는 가장 앞에 있는 요소를 참조하는데 큐에 push했던 (sy, sx)가 아닌 (y, x)가 되는지 이해가 되지 않아서 질문드립니다! 어떻게 push하지 않은 (y, x)가 큐 맨앞에 요소로 참조될 수 있는지 궁금합니다!
// 아래는 제 질문에 해당하는 코드입니다
while ( q.size() ) {
tie ( y , x ) = q.front() ; q.pop() ; // ----???
답변 1
1
안녕하세요 1209님 ㅎㅎ
그 다음 q.front()를 통해 큐에 있는 가장 앞에 있는 요소를 참조하는데 큐에 push했던 (sy, sx)가 아닌 (y, x)가 되는지 이해가 되지 않아서 질문드립니다! 어떻게 push하지 않은 (y, x)가 큐 맨앞에 요소로 참조될 수 있는지 궁금합니다!
// 아래는 제 질문에 해당하는 코드입니다
while ( q.size() ) {
tie ( y , x ) = q.front() ; q.pop() ; // ----???
>> 자,
sy, sx를 q에 집어넣습니다.
자 그러면 q에는 {sy, sx}가 들어가있겠죠?
근데 이 요소는. q.front() 라는 메서드로 참조가 가능한거에요.
이 때 이 변수를 y, x로 놓던 b, c로 놓던 상관없습니다. 모든 변수도로 참조가 가능해요. 즉, 넣은 sy, sx를 q.front라는 메서드로 끄집어내서 ~~~ 다른 변수로 만들어 참조하는 것입니다.
예를 들어.
#include<bits/stdc++.h>
using namespace std;
const int max_n = 104;
int dy[4] = {-1, 0, 1, 0};
int dx[4] = {0, 1, 0, -1};
int n, m, a[max_n][max_n], visited[max_n][max_n], y, x, sy, sx, ey, ex;
int main(){
scanf("%d %d", &n, &m);
cin >> sy >> sx;
cin >> ey >> ex;
for(int i = 0; i < n; i++){
for(int j = 0; j < m; j++){
cin >> a[i][j];
}
}
queue<pair<int, int>> q;
visited[sy][sx] = 1;
q.push({sy, sx});
while(q.size()){
int b, c;
tie(b, c) = q.front(); q.pop();
for(int i = 0; i < 4; i++){
int ny = b + dy[i];
int nx = c + dx[i];
if(ny < 0 || ny >= n || nx < 0 || nx >= m || a[ny][nx] == 0) continue;
if(visited[ny][nx]) continue;
visited[ny][nx] = visited[y][x] + 1;
q.push({ny, nx});
}
}
printf("%d\n", visited[ey][ex]);
// 최단거리 디버깅
for(int i = 0; i < n; i++){
for(int j = 0; j < m; j++){
cout << visited[i][j] << ' ';
}
cout << '\n';
}
return 0;
}
이렇게 해도 됩니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제가 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
코딩 살구 클럽 컴파일 에러
0
4
1
추천 문제
0
7
1
코딩살구클럽 승인
0
9
1
코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의
0
21
2
문제를 고민하는 시간 관련
0
26
2
코딩살구클럽
0
38
2
코딩살구클럽 문의
0
37
2
코딩살구클럽 승인
0
35
2
DP 경우의 수 설명이 이해가 되지 않습니다.
0
33
2
3-F 채점 관련 질문
0
31
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
33
2
코딩살구클럽 승인
0
45
2
코딩살구클럽승인
0
39
3
코딩살구클럽 승인
0
54
2
3-D 관련 질문
0
35
2
코살구 회원가입 문의
0
45
2
코살구 로그인 문제
0
65
2
3-A 문제 풀이 관련 질문
0
56
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
63
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
67
2
코딩살구클럽 로그인문제
0
85
3
코딩 살구 클럽 로그인 문제
0
86
2





