Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- amba
- chip2chip
- 정처기
- 정보처리기사
- linux
- AMBA BUS
- baekjoon
- Beakjoon
- C++
- 코딩테스트
- Zynq
- axi
- 백준
- 실기
- SQL
- verilog
- Bus
- java
- UNIX
- vitis
- Vivado
- boj
- 리눅스
- hdl
- HDLBits
- FPGA
- Xilinx
- 자격증
- verilog HDL
- Backjoon
Archives
- Today
- Total
Hueestory
[2178] 미로 탐색 (C++) 본문
#include <iostream>
#include <vector>
#include <queue>
#include <algorithm>
#define MAX 101
using namespace std;
int maze[MAX][MAX];
int visited[MAX][MAX];
int dx[4] = { -1, 1, 0, 0 };
int dy[4] = { 0, 0, -1, 1 };
int N, M;
int BFS(int x, int y);
int main() {
ios::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
cin >> N >> M;
string s;
for (int i = 0; i < N; i++) {
cin >> s;
for (int j = 0; j < M; j++)
maze[i][j] = s[j] - '0';
}
cout << BFS(0, 0) << endl;
return 0;
}
int BFS(int x, int y) {
queue<pair<int, int>> q;
q.push({ x, y });
visited[x][y] = 1;
while (!q.empty()) {
int tmp_x = q.front().first;
int tmp_y = q.front().second;
q.pop();
for (int i = 0; i < 4; i++) {
int new_x = tmp_x + dx[i];
int new_y = tmp_y + dy[i];
if (new_x < 0 || new_x >= N || new_y < 0 || new_y >= M) continue;
if (maze[new_x][new_y] == 0) continue;
if (visited[new_x][new_y] != 0) continue;
visited[new_x][new_y] = visited[tmp_x][tmp_y] + 1;
q.push({ new_x, new_y });
}
}
return visited[N - 1][M - 1];
}
1. 미로를 담을 배열과 방문 횟수를 기록할 배열을 생성
2. 상 하 좌 우를 나타낼 dx, dy를 생성
3. BFS를 사용, 좌표값이 미로 밖을 나타내거나 / 값이 0 이거나 / 방문 횟수가 0이 아니라면 해당 위치로 이동하지 않음
4. 다음 위치로 이동한 후 방문 횟수를 증가시킴
5. 도착 위치의 방문 횟수 값을 반환하여 출력
'PS(중단) > BOJ' 카테고리의 다른 글
[1920] 수 찾기 (C++) (0) | 2024.05.07 |
---|---|
[1167] 트리의 지름 (C++) (0) | 2024.05.07 |
[1260] DFS와 BFS (C++) (0) | 2024.05.03 |
[1978] 소수 찾기 (C++) (1) | 2024.05.01 |
[13023] ABCDE (C++) (0) | 2024.05.01 |
Comments