Henu
개발냥발
Henu
전체 방문자
오늘
어제
  • 분류 전체보기 (411)
    • DevOps (52)
      • Kubernetes (19)
      • Docker (14)
      • AWS (3)
      • Nginx (4)
      • Linux (4)
      • ArgoCD (1)
      • CN (2)
      • NATS (0)
      • Git (5)
    • Back-End (30)
      • Django (18)
      • Spring (5)
      • JPA (1)
      • MSA (5)
    • CS (87)
      • SystemSoftware (20)
      • OS (25)
      • Computer Architecture (16)
      • Network (23)
      • Database (2)
    • Lang (21)
      • Java (9)
      • Python (4)
      • C# (8)
    • Life (12)
    • 블록체인 (2)
    • Algorithm (204)
      • BOJ (160)
      • 프로그래머스 (19)
      • LeetCode (4)
      • SWEA (1)
      • 알고리즘 문제 해결 전략 (8)
      • DS, algorithms (7)
      • Checkio (5)
    • IT (2)

블로그 메뉴

  • GitHub
  • 글쓰기
  • 관리자

공지사항

  • Free!

인기 글

태그

  • 프로그래머스
  • 다이나믹 프로그래밍
  • DFS
  • docker
  • django
  • Kubernetes
  • 백트래킹
  • boj
  • Network
  • BFS

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Henu

개발냥발

[백준 1600] 말이 되고픈 원숭이 C++
Algorithm/BOJ

[백준 1600] 말이 되고픈 원숭이 C++

2021. 6. 9. 12:38
 

1600번: 말이 되고픈 원숭이

첫째 줄에 정수 K가 주어진다. 둘째 줄에 격자판의 가로길이 W, 세로길이 H가 주어진다. 그 다음 H줄에 걸쳐 W개의 숫자가 주어지는데, 0은 아무것도 없는 평지, 1은 장애물을 뜻한다. 장애물이 있

www.acmicpc.net

BFS


1. 문제 해결 아이디어

이동할 수 있는 방향이 동서남북 외에도 체스의 말(house)이 움직일 수 있는 8방향이 추가된 문제이다.

 

처음엔 그냥 8방향만 추가해 주고, 말이 움직이는 방향을 먼저 탐색해 주면 풀리겠지 해서 빠르게 틀렸다.

 

 

 

[백준 14442] 벽 부수고 이동하기2 C++

14442번: 벽 부수고 이동하기 2 첫째 줄에 N(1 ≤ N ≤ 1,000), M(1 ≤ M ≤ 1,000), K(1 ≤ K ≤ 10)이 주어진다. 다음 N개의 줄에 M개의 숫자로 맵이 주어진다. (1, 1)과 (N, M)은 항상 0이라고 가정하자. www.a..

hyeo-noo.tistory.com

위 문제에서 적용했던 것처럼 방문 여부를 3차원으로 만들어줘야 한다.

 

무조건 말처럼 이동을 먼저하는게 아니라 일반 이동을 먼저 할 수도 있기 때문이다.

 

1
4 4
0 0 0 0
1 0 0 0
0 0 1 1
0 1 0 0
같은 경우에는 
(0, 0) > (0, 1) >  (1, 1) >  (2, 1) > 말처럼 이동 > (3, 3) 이 답이 되기 때문이다.

2. 코드

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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#include <iostream>
#include <queue>
 
#define pii pair<int, int>
using namespace std;
 
struct P{
    int r, c;
    int k;
    int cnt;
};
 
int K, W, H;
int Map[201][201];
bool visited[201][201][31];
int dr[4] = {0, 0, 1, -1}, dc[4] = {1, -1, 0, 0};
int hr[8] = {1, 1, 2, 2, -1, -1, -2, -2};
int hc[8] = {-2, 2, -1, 1, -2, 2, -1, 1};
 
void BFS(){
    int cnt = 0;
    
    queue<P> que;
    que.push({0, 0, 0, 0});
    for(int i = 0; i <= K; i++){
        visited[0][0][i] = true;
    }
    
    while(!que.empty()){
        P now = que.front();
        que.pop();
        
        if(now.r == H-1 && now.c == W-1){
            cout << now.cnt << "\n";
            return;
        }
        
        if(now.k < K){
            for(int i = 0; i < 8; i++){
                int nr = now.r + hr[i];
                int nc = now.c + hc[i];
                
                // 말 처럼 k+1번 이동했을 때 방문하지 않았다면
                if(nr < 0 || nr >= H || nc < 0 || nc >= W || Map[nr][nc] || visited[nr][nc][now.k+1]) continue;
                visited[nr][nc][now.k+1] = true;
                que.push({nr, nc, now.k+1, now.cnt+1});
            }
        }
        
        for(int i = 0; i < 4; i++){
            int nr = now.r + dr[i];
            int nc = now.c + dc[i];
            
            // 말 처럼 k번 이동했을 때 방문하지 않았다면 
            if(nr < 0 || nr >= H || nc < 0 || nc >= W || Map[nr][nc] || visited[nr][nc][now.k]) continue;
            visited[nr][nc][now.k] = true;
            que.push({nr, nc, now.k, now.cnt+1});
        }
    }
    cout << -1;
}
 
void input(){
    cin >> K >> W >> H;
    
    for(int i = 0; i < H; i++){
        for(int j = 0; j < W; j++){
            cin >> Map[i][j];
        }
    }
}
 
int main(){
    input();
    BFS();
    return 0;
}
 
Colored by Color Scripter
cs
 

맨날 2차원 방문 배열만 쓰니까 다른것도 써보라고 가르쳐준 문제

'Algorithm > BOJ' 카테고리의 다른 글

[백준 17387] 선분 교차 2 C++  (1) 2021.06.11
[백준 2150] Strongly Connected Component C++  (0) 2021.06.10
[백준 8980] 택배 C++  (0) 2021.06.09
[백준 1167] 트리의 지름 C++  (0) 2021.06.07
[백준 1328] 고층 빌딩 C++  (0) 2021.06.07
    'Algorithm/BOJ' 카테고리의 다른 글
    • [백준 17387] 선분 교차 2 C++
    • [백준 2150] Strongly Connected Component C++
    • [백준 8980] 택배 C++
    • [백준 1167] 트리의 지름 C++

    티스토리툴바