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 |
Tags
- COSPRO
- PS
- 게더타운시작
- 다이나믹프로그래밍
- spring
- 취득후기
- YBMCOS
- BFS
- 백준코딩테스트
- 알고리즘
- 완전탐색
- 이젠 골드구현도 어렵네..
- 우선순위큐
- 재귀함수
- 백준
- 01BFS
- java
- COSPROJAVA1급
- 엘라스틱서치
- 네트워크플로우
- 시뮬레이션
- 자바PS
- GatherTown
- DFS
- dp
- deque
- 다익스트라
- 구현
- 세그먼트트리
- QUICKSTARTGUIDE
Archives
- Today
- Total
공부공간
BOJ - 1938 ) 통나무 옮기기 본문
https://www.acmicpc.net/problem/1938
시뮬 + BFS문제이다. 통나무가 특정위치에 왔을때 방문체크를 해주기 위하여 3차원 VISIT 배열을 사용한다.
딱히 문제에 설명이 잘되어있어서 어렵지는 않지만, 조건들을 확실하게 체크해줘야한다.
통나무가 회전하면 VISIT 배열의 최상위 인덱스를 바꿔주는 식으로 구현하였다..
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayDeque;
import java.util.StringTokenizer;
public class 통나무옮기기 {
static class tree{
int y,x,shape,time;
public tree(int y, int x, int shape, int time) {
this.y = y;
this.x = x;
this.shape = shape;
this.time = time;
}
}
public static char map[][];
public static boolean visit[][][];
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
int n = Integer.parseInt(st.nextToken());
map = new char[n+1][n+1];
int centerx=0 , centery=0,shape =0,endx =0,endy=0,endshape=0;
for(int i = 1 ; i <=n ; i++) {
char temp[] = br.readLine().toCharArray();
for(int j =1 ; j <=n ; j++) {
map[i][j] = temp[j-1];
}
}
for(int i = 1 ; i <=n ; i++) {
for(int j=1 ; j <= n; j++) {
if(map[i][j] =='B') {
if(i-1 >0 && i+1 <=n) {
if(map[i-1][j] =='B' && map[i+1][j]=='B') {
map[i-1][j] ='0'; map[i+1][j]='0'; map[i][j]='0';
centerx = j ; centery=i ; shape =1;
}
}
if(j-1 >0 && j+1 <=n) {
if(map[i][j-1]=='B' && map[i][j+1]=='B') {
map[i][j-1]='0'; map[i][j+1]='0'; map[i][j]='0';
centerx = j ; centery=i ; shape =2;
}
}
} else if(map[i][j]=='E') {
if(i-1 >0 && i+1 <=n ) {
if(map[i-1][j] =='E' && map[i+1][j]=='E') {
map[i-1][j] ='0' ; map[i+1][j]='0'; map[i][j]='0';
endx = j ;endy=i ; endshape =1;
}
}
if (j-1 > 0 && j+1 <=n) {
if(map[i][j-1]=='E' && map[i][j+1]=='E') {
map[i][j-1]='0';map[i][j+1]='0'; map[i][j]='0';
endx = j ; endy=i ; endshape =2;
}
}
}
}
}
int dir[][] = {{0,1},{0,-1},{1,0},{-1,0},{1,-1},{1,1},{-1,1},{-1,-1}};
int answer =0;
visit = new boolean[3][n+1][n+1];
ArrayDeque<tree> dq = new ArrayDeque<tree>();
dq.add(new tree(centery, centerx, shape,0));
visit[shape][centery][centerx] = true;
while(!dq.isEmpty()) {
tree now = dq.poll();
int y = now.y;
int x = now.x;
int nowshape = now.shape;
int time = now.time;
if(y==endy && x == endx && nowshape == endshape) {
answer = time;
break;
}
for(int index = 0 ; index < 4 ; index++) {
if(nowshape == 1) {
int ny = y +dir[index][0];
int nx = x +dir[index][1];
if(ny>0 && nx >0 && nx<= n && ny<=n && ny+1 <=n && ny-1>0) {
if(map[ny][nx]=='0' && map[ny+1][nx]=='0' && map[ny-1][nx] =='0') {
if(!visit[nowshape][ny][nx]) {
visit[nowshape][ny][nx] = true;
dq.add(new tree(ny,nx,nowshape,time+1));
}
}
}
} else if(nowshape==2){
int ny = y +dir[index][0];
int nx = x +dir[index][1];
if(ny>0 && nx >0 && nx<= n && ny<=n && nx+1 <=n && nx-1>0) {
if(map[ny][nx]=='0' && map[ny][nx+1]=='0' && map[ny][nx-1] =='0') {
if(!visit[nowshape][ny][nx]) {
visit[nowshape][ny][nx] = true;
dq.add(new tree(ny,nx,nowshape,time+1));
}
}
}
}
}
// 회전연산 cnt가 6이고 visit처리가 안되있으면 go
int cnt = 0;
for(int index = 0 ; index < 8 ; index++) {
int ny = y + dir[index][0];
int nx = x + dir[index][1];
if(ny>0 && nx>0 && nx <=n && ny<=n) {
if(map[ny][nx]=='0') cnt++;
}
}
if(cnt==8) {
if(nowshape==1 && !visit[2][y][x]) {
visit[2][y][x] = true;
dq.add(new tree(y,x,2,time+1));
}else if(nowshape==2 && !visit[1][y][x]) {
visit[1][y][x] = true;
dq.add(new tree(y,x,1,time+1));
}
}
}System.out.print(answer);
}
}
'알고리즘 > 완전탐색(BFS,DFS)' 카테고리의 다른 글
BOJ - 14868 ) 문명 (0) | 2020.04.18 |
---|---|
BOJ - 3197 ) 백조의호수 (0) | 2020.04.18 |
BOJ - 1325 ) 효율적인해킹 (0) | 2020.04.06 |
BOJ - 2206 ) 벽부수고 이동하기 (0) | 2020.03.18 |
BOJ - 6593 ) 상범빌딩 (0) | 2020.03.18 |
Comments