인프런 커뮤니티 질문&답변

dkswhdgur1209님의 프로필 이미지
dkswhdgur1209

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

2주차 개념 #10. 너비우선탐색(BFS, Breadth First Search)

당근마킷 엔지니어 승원이 예제에 대한 질문입니다

작성

·

486

0

안녕하세요 강사님

승원이 예제를 풀다가 궁금한 것이 있어 질문드립니다.

승원이의 위치(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점은 제가 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

dkswhdgur1209님의 프로필 이미지
dkswhdgur1209
질문자

좋은 말씀 감사합니다!

그렇다면, tie(y, x) 를 쓰지않고 원본값인 tie(sy, sx)를 써도 되는 것인가요!?

dkswhdgur1209님의 프로필 이미지
dkswhdgur1209

작성한 질문수

질문하기