반응형
    
    
    
  
1. 시뮬레이션으로 10번 이내로 움직이는 모든 경우를 다 시도해본다.
1. 시뮬레이션으로 10번 이내로 움직이는 모든 경우를 다 시도해본다.
시뮬레이션 문제였다. 보드 기울여 구슬 움직이는 것을 잘 구현해준 뒤, DFS를 이용해서 10번 이내로 움직이는 모든 경우를 다 시도해준다. 각 depth에서 상하좌우로 움직이는 경우 전부를 시도해주어야 한다.
반응형
    
    
    
  #include <iostream>
#include <algorithm>
using namespace std;
const int MAX = 10;
const int U = 0, D = 1, L = 2, R = 3;
const int RED = 100, BLUE = 200;
struct Marble {
    int r, c;
    char color;
};
int N, M;
Marble H;
char board[MAX][MAX];
int dr[] = {-1, 1, 0, 0};
int dc[] = {0, 0, -1, 1};
bool operator== (const Marble& lhs, const Marble& rhs) {
    return lhs.r == rhs.r && lhs.c == rhs.c;
}
bool fallIntoHole(Marble m) {
    return m == H;
}
Marble move(int dir, Marble m) {
    Marble ret = m;
    
    while (!fallIntoHole(ret)) {
        int nr = ret.r + dr[dir];
        int nc = ret.c + dc[dir];
        
        if (board[nr][nc] == '#' || board[nr][nc] == 'R' || board[nr][nc] == 'B') break;
        
        ret.r = nr;
        ret.c = nc;
    }
    
    board[m.r][m.c] = '.';
    if (!fallIntoHole(ret)) board[ret.r][ret.c] = m.color;
    
    return ret;
}
int firstMove(int dir, Marble red, Marble blue) {
    switch (dir) {
        case U: return red.r <= blue.r ? RED : BLUE;
        case D: return red.r >= blue.r ? RED : BLUE;
        case L: return red.c <= blue.c ? RED : BLUE;
        case R: return red.c >= blue.c ? RED : BLUE;
        default: return 0;
    }
}
bool DFS(int depth, Marble red, Marble blue) {
    if (depth > 10) return false;
    if (fallIntoHole(blue)) return false;
    if (fallIntoHole(red)) return true;
    
    char temp[MAX][MAX];
    copy(&board[0][0], &board[0][0]+MAX*MAX, &temp[0][0]);
    
    for (int i=0; i<4; i++) {
        Marble newRed, newBlue;
        
        if (firstMove(i, red, blue) == RED) {
            newRed = move(i, red);
            newBlue = move(i, blue);
        }
        else {
            newBlue = move(i, blue);
            newRed = move(i, red);
        }
        
        if (red == newRed && blue == newBlue) continue;
        if (DFS(depth+1, newRed, newBlue)) return true;
        
        copy(&temp[0][0], &temp[0][0]+MAX*MAX, &board[0][0]);
    }
    
    return false;
}
int main()
{
    cin >> N >> M;
    
    Marble red, blue;
    string temp;
    
    for (int i=0; i<N; i++) {
        cin >> temp;
        
        for (int j=0; j<M; j++) {
            board[i][j] = temp[j];
            
            if (temp[j] == 'R') red = {i, j, 'R'};
            else if (temp[j] == 'B') blue = {i, j, 'B'};
            else if (temp[j] == 'O') H = {i, j, 'O'};
        }
    }
    
    if (DFS(0, red, blue)) cout << 1;
    else cout << 0;
    return 0;
}
반응형
    
    
    
  'Problem Solving > BOJ' 카테고리의 다른 글
| 백준 2294번 동전 2 - C++ 풀이 (0) | 2022.06.05 | 
|---|---|
| 백준 2211번 네트워크 복구 - C++ 풀이 (0) | 2022.06.04 | 
| 백준 2573번 빙산 - C++ 풀이 (0) | 2022.06.02 | 
| 백준 1058번 친구 - C++ 풀이 (0) | 2022.06.01 | 
| 백준 5676번 음주 코딩 - C++(cpp) 풀이 (0) | 2022.05.31 | 
 
										
									 
										
									 
										
									 
										
									
댓글