일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- toUpperCase
- mysql hy000 에러
- ac 5430번
- replace()
- 백준 1541
- 백준 14938번 서강그라운드
- Stack
- 백준 3190번
- append
- dp
- 백준 1647번 도시 분할 계획 - java
- hash
- HashMap
- HashSet
- 백준 1197번 최소 스패닝 트리 - java
- StringBuilder
- kotlin
- 코틀린기초
- 프로그래머스 java
- StringTokenizer
- 백준 1806번 부분합 java
- map
- 프로그래머스
- 18111번 마인크래프트 - java 구현
- 최소 힙 1927
- 백준 2467번 용액 자바 - 이분탐색
- 백준 1043번 거짓말 - java 분리 집합
- 프로그래머스 자바
- Java
- 백준 2473번 세 용액 - java
Archives
- Today
- Total
말하는 컴공감자의 텃밭
알고리즘 재활 3일차 - 백준 15652, 2636번 본문
728x90
N과 M (4)
중복이 안되게, 앞수보다는 뒤 수가 더 크게 수열을 만들어 주면 된다.
숫자 길이에 맞게 depth를 짜주고, start로 중복을 막아주어 수열을 뽑아내면 꿋.
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 | import java.io.*; import java.util.*; public class Main { // S3 N과 M(3) static int N, M; static int[] arr; static StringBuilder sb = new StringBuilder(); public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringTokenizer st = new StringTokenizer(br.readLine()); N = Integer.parseInt(st.nextToken()); M = Integer.parseInt(st.nextToken()); arr = new int[M]; dfs(0, 1); System.out.println(sb); } public static void dfs(int depth, int start) { if (depth == M) { for (int val : arr) { sb.append(val).append(" "); } sb.append("\n"); return; } // start 변수로 중복 방지 for (int i = start; i <= N; i++) { arr[depth] = i; dfs(depth + 1, i); } } } | cs |
치즈
외부 공기와 두면 이상 맞닿은 치즈는 녹고만다..
이 치즈들이 다 녹는데 얼마나 걸리는지 시간을 구하는 문제다.
요즘 너무 덥잖아요 그쵸?
가장 중요한 포인트는 외부 공기와 치즈에 감싸진 내부 공기를 구별하는것이다.
어떻게 작성할지 sudo 코드를 간단하게 작성해 풀었다.
코드가 굉장히.. 장황하게 나왔다.
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 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 | import java.io.*; import java.util.*; public class Main { // G3 치즈 static int N, M, cheeseCnt; static int[][] cheese; static boolean[][] visited; static int[] dr = {1, -1, 0, 0}; static int[] dc = {0, 0, -1, 1}; static StringBuilder sb = new StringBuilder(); public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringTokenizer st = new StringTokenizer(br.readLine()); N = Integer.parseInt(st.nextToken()); M = Integer.parseInt(st.nextToken()); cheese = new int[N][M]; cheeseCnt = 0; int time = 0; // input for (int i = 0; i < N; i++) { st = new StringTokenizer(br.readLine()); for (int j = 0; j < M; j++) { cheese[i][j] = Integer.parseInt(st.nextToken()); if (cheese[i][j] == 1) { cheeseCnt++; } } } while (cheeseCnt != 0) { // 외부 공기 체크 outsideAir(0, 0); bfs(0, 0); // showmetheMap(); time++; } System.out.println(time); } // 치즈 탐색 로직 public static void bfs(int r, int c) { visited = new boolean[N][M]; Queue<int[]> que = new ArrayDeque<>(); for (int i = 0; i < N; i++) { for (int j = 0; j < M; j++) { if (cheese[i][j] != 1 || visited[i][j]) { continue; } que.add(new int[]{i, j}); visited[i][j] = true; } } while (!que.isEmpty()) { int[] now = que.poll(); int nowR = now[0]; int nowC = now[1]; // 근처 외부공기 2면 이상 맞닿으면 외부공기로 전환 if (nearAirchk(nowR, nowC)) { cheese[nowR][nowC] = 2; cheeseCnt--; } for (int k = 0; k < 4; k++) { int nextR = nowR + dr[k]; int nextC = nowC + dc[k]; if (!rangeChk(nextR, nextC) || cheese[nextR][nextC] != 1) { continue; } visited[nextR][nextC] = true; que.add(new int[]{nextR, nextC}); } } } // 외부공기인지 판단 public static void outsideAir(int r, int c) { visited = new boolean[N][M]; Queue<int[]> que = new ArrayDeque<>(); que.add(new int[]{0, 0}); visited[0][0] = true; while (!que.isEmpty()) { int[] now = que.poll(); int nowR = now[0]; int nowC = now[1]; if (cheese[nowR][nowC] == 0) { cheese[nowR][nowC] = 2; } for (int k = 0; k < 4; k++) { int nextR = nowR + dr[k]; int nextC = nowC + dc[k]; if (!rangeChk(nextR, nextC) || cheese[nextR][nextC] == 1) { continue; } visited[nextR][nextC] = true; que.add(new int[]{nextR, nextC}); } } } // 해당 치즈 주변에 외부공기 있는지 체크 public static boolean nearAirchk(int r, int c) { int cnt = 0; for (int k = 0; k < 4; k++) { int nextR = r + dr[k]; int nextC = c + dc[k]; if (!rangeChk(nextR, nextC)) { continue; } if (cheese[nextR][nextC] == 2) { cnt++; } } return cnt >= 2; } public static boolean rangeChk(int r, int c) { return 0 <= r && r < N && 0 <= c && c < M && !visited[r][c]; } public static void showmetheMap() { for (int i = 0; i < N; i++) { for (int j = 0; j < M; j++) { System.out.print(cheese[i][j] + " "); } System.out.println(); } System.out.println(); } } | cs |
728x90
'알고리즘 > Backjoon - Java' 카테고리의 다른 글
알고리즘 재활 5일차 - 백준 27648, 26043, 2817번 (0) | 2024.08.02 |
---|---|
알고리즘 재활 4일차 - 백준 2805, 15686번 (0) | 2024.08.01 |
알고리즘 재활 2일차 - 백준 2751, 10814, 11726, 1074번 (0) | 2024.07.30 |
알고리즘 재활 1일차 - 백준 1620, 10828, 1764번 (0) | 2024.07.29 |
백준 1600번 말이 되고픈 원숭이 G3 - BFS (1) | 2024.04.27 |
Comments