티스토리 뷰
17143번: 낚시왕
낚시왕이 상어 낚시를 하는 곳은 크기가 R×C인 격자판으로 나타낼 수 있다. 격자판의 각 칸은 (r, c)로 나타낼 수 있다. r은 행, c는 열이고, (R, C)는 아래 그림에서 가장 오른쪽 아래에 있는 칸이다.
www.acmicpc.net
data:image/s3,"s3://crabby-images/54e58/54e58b8be64b06d0e50f8e3a44fcb71f98d5175f" alt=""
data:image/s3,"s3://crabby-images/7887e/7887ecda938ec5a63fb37fa8a220cc9470a127a1" alt=""
data:image/s3,"s3://crabby-images/39bcc/39bcc06bc3970f196ddc436d2c09bf4c452027ff" alt=""
import java.io.*; import java.util.*; // 210423 public class Main_BJ_17143_낚시왕 { static int R, C, M, total; static int[] dr = {-1, 1, 0, 0}; // 상 하 우 좌 static int[] dc = {0, 0, 1, -1}; static Shark[][] map; static class Shark { int idx, s, d, z; // 번호, 속력, 이동방향, 크기 public Shark(int idx, int s, int d, int z) { this.idx = idx; this.s = s; this.d = d; this.z = z; } } public static void main(String[] args) throws Exception { //System.setIn(new FileInputStream("res/input_BJ_17143_낚시왕.txt")); BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringTokenizer st = new StringTokenizer(br.readLine(), " "); R = stoi(st.nextToken()); C = stoi(st.nextToken()); M = stoi(st.nextToken()); total = 0; map = new Shark[R+1][C+1]; for(int i=1; i<=M; i++) { // 상어는 1번부터 시작 st = new StringTokenizer(br.readLine(), " "); int r = stoi(st.nextToken()); int c = stoi(st.nextToken()); int s = stoi(st.nextToken()); int d = stoi(st.nextToken())-1; int z = stoi(st.nextToken()); map[r][c] = new Shark(i, s, d, z); } solve(); System.out.println(total); br.close(); } static void solve() { for(int playercol = 1; playercol<=C; playercol++) { // 1. 같은 열에서 땅과 가장 가까운 상어를 잡는다. getShark(playercol); // 2. 상어가 없어진다. map = sharkMove(); } } // 1. 낚시꾼이 오른쪽 열로 움직이며, // 같은 열에 있는 상어 중 땅에서 가장 가까운 상어를 잡는다. static void getShark(int playercol) { ArrayList<int[]> list = new ArrayList<int[]>(); for(int r = 1; r<=R; r++) { if(map[r][playercol]!=null) { Shark target = map[r][playercol]; total += target.z; map[r][playercol] = null; return; } } } // 2. 상어들이 움직인다. static Shark[][] sharkMove() { Shark[][] newMap = new Shark[R+1][C+1]; for(int i=1; i<=R; i++) { for(int j=1; j<=C; j++) { if(map[i][j]==null) continue; Shark shark = map[i][j]; int nr = i, nc = j; for(int k=1; k<=shark.s; k++) { nr += dr[shark.d]; nc += dc[shark.d]; // 이동 중간에 범위를 넘어가면 방향만 바꾼다. if(nr<1 || nr>R || nc<1 || nc>C) { nr -= dr[shark.d]; nc -= dc[shark.d]; shark.d = flipDir(shark.d); nr += dr[shark.d]; nc += dc[shark.d]; } } // 도착지 if(newMap[nr][nc]!=null) { // 더 큰 상어만 남는다. if(newMap[nr][nc].z < shark.z) { newMap[nr][nc] = null; newMap[nr][nc] = new Shark(shark.idx, shark.s, shark.d, shark.z); } } else { newMap[nr][nc] = new Shark(shark.idx, shark.s, shark.d, shark.z); } } } return newMap; } static int flipDir(int dir) { if(dir==0) { return 1; } else if(dir==1) { return 0; } else if(dir==2) { return 3; } else if(dir==3) { return 2; } return 0; } static int stoi(String str) { return Integer.parseInt(str); } }
'코딩테스트 > 백준' 카테고리의 다른 글
[BJ] 20057. 마법사 상어와 토네이도 (0) | 2021.04.24 |
---|---|
[BJ] 17142. 연구소 3 (0) | 2021.04.23 |
[BJ] 20056. 마법사 상어와 파이어볼 (0) | 2021.04.23 |
[BJ] 2636. 치즈 (0) | 2021.04.22 |
[BJ] 19238. 스타트 택시 (0) | 2021.04.21 |
댓글