[Programmers] 1844 게임 맵 최단거리 (C++)PS/프로그래머스[programmers]2025. 7. 9. 21:20
      Table of Contents
        728x90
    
    
  반응형
    
    
    
  문제
https://school.programmers.co.kr/learn/courses/30/lessons/1844
프로그래머스
SW개발자를 위한 평가, 교육의 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
풀이
문제를 읽으면 Flood fill을 사용하는 문제임을 알 수 있다. 잠시 Flood fill을 알아보면,
Flood fill이란?
2차원 배열(혹은 다차원 배열)에서 주어진 시작점과 연결된 영역 전체를 찾아서 특정 값(색상 등)으로 바꾸는 알고리즘
Flood fill을 이용한 BFS의 기본적인 예제 문제이다. (0, 0)에서 (n-1, m-1)까지의 최단 경로를 찾아야 한다. 프로그래머스 특성상 다음의 처리만 잘 해주면 된다.
- 방문할 수 없는 경우 -1 예외 처리
- 프로그래머스 환경이므로 solution함수 안에서 N, M 초기화하기
코드
#include<iostream>
#include<queue>
#include<vector>
#define IN(Y, X) (Y < N && Y >= 0 && X < M && X >= 0)
#define FAST_IO cin.tie(0), cout.tie(0), ios_base::sync_with_stdio(0)
#define F first
#define S second
using namespace std;
typedef pair<int, int> PII;
int dy[4] = { 1, 0, -1, 0 };
int dx[4] = { 0, 1, 0, -1 };
bool visit[100][100];
queue<PII> que;
int solution(vector<vector<int>> maps) {
	int answer = -1;
    
    int N = maps.size();
    int M = maps[0].size();
	que.push({ 0, 0 });
	visit[0][0] = true;
	while (!que.empty()) {
		PII cur = que.front();
		que.pop();
		int cy = cur.F;
		int cx = cur.S;
		if (cy == N - 1 && cx == M - 1) return maps[cy][cx];
		for (int i = 0; i < 4; i++) {
			int ny = cy + dy[i];
			int nx = cx + dx[i];
			if (IN(ny, nx) && maps[ny][nx] == 1 && !visit[ny][nx]) {
				maps[ny][nx] = maps[cy][cx] + 1; // cnt 
				visit[ny][nx] = true;
				que.push({ ny, nx });
			}
		}
	}
	return answer;
}
728x90
    
    
  반응형
    
    
    
  'PS > 프로그래머스[programmers]' 카테고리의 다른 글
| [Programmers] 17679 프렌즈4블록 (C++) (2) | 2025.07.10 | 
|---|---|
| [Programmers] 주식 가격 (2) | 2024.12.19 | 
@BE_개발자 :: 경이로운 개발일기
            경이로운 BE 개발자가 되기 위한 프로그래밍 공부 기록장
도움이 되었다면 "❤️" 또는 "👍🏻" 해주세요! 문의는 아래 이메일로 보내주세요.
![[Programmers] 17679 프렌즈4블록 (C++)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2FTPYFt%2FbtsPdgTNii0%2FAAAAAAAAAAAAAAAAAAAAADNFS_2jLJyUtKbVPQgtwFpHe7IshlZCzep4AhPr2a35%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3Dj08ujC4lj4myDflkJM9qR%252Fxvcrg%253D) 
                  ![[Programmers] 주식 가격](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2Fc31caC%2FbtsLoha9K7D%2FAAAAAAAAAAAAAAAAAAAAADRiRMIL_44a_gcvtW6RPRusBjdNVUw_dZuLfNW__uxM%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3DhOm7r%252F0WfXRc5jC0pUHS%252F%252BVagPQ%253D)