From ab9f4dabea888a43680308f8f13ddc53cdfbfb91 Mon Sep 17 00:00:00 2001 From: Meenzino <86910955+Minzino@users.noreply.github.com> Date: Fri, 24 Feb 2023 18:49:21 +0900 Subject: [PATCH] =?UTF-8?q?solution:=20=EC=99=B8=EB=B2=BD=EC=A0=90?= =?UTF-8?q?=EA=B2=80=20=EC=8B=A4=ED=8C=A8=20-=20=ED=8C=A8=ED=82=A4?= =?UTF-8?q?=EC=A7=80=20=EC=A0=95=EB=A6=AC(=EB=B0=B1=EC=A4=80=EA=B3=BC=20?= =?UTF-8?q?=ED=94=84=EB=A1=9C=EA=B7=B8=EB=9E=98=EB=A8=B8=EC=8A=A4=EB=A1=9C?= =?UTF-8?q?=20=EB=B6=84=EB=A6=AC)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../feb/{ => backjoon}/bj20310/Main.java | 2 +- .../Solution.java" | 69 +++++++++++++++++++ 2 files changed, 70 insertions(+), 1 deletion(-) rename minzino/java/src/main/java/org/example/feb/{ => backjoon}/bj20310/Main.java (95%) create mode 100644 "minzino/java/src/main/java/org/example/feb/programmers/\354\231\270\353\262\275_\354\240\220\352\262\200/Solution.java" diff --git a/minzino/java/src/main/java/org/example/feb/bj20310/Main.java b/minzino/java/src/main/java/org/example/feb/backjoon/bj20310/Main.java similarity index 95% rename from minzino/java/src/main/java/org/example/feb/bj20310/Main.java rename to minzino/java/src/main/java/org/example/feb/backjoon/bj20310/Main.java index 8a20eef..4b08448 100644 --- a/minzino/java/src/main/java/org/example/feb/bj20310/Main.java +++ b/minzino/java/src/main/java/org/example/feb/backjoon/bj20310/Main.java @@ -1,4 +1,4 @@ -package main.java.org.example.feb.bj20310; +package main.java.org.example.feb.backjoon.bj20310; import java.io.BufferedReader; import java.io.IOException; diff --git "a/minzino/java/src/main/java/org/example/feb/programmers/\354\231\270\353\262\275_\354\240\220\352\262\200/Solution.java" "b/minzino/java/src/main/java/org/example/feb/programmers/\354\231\270\353\262\275_\354\240\220\352\262\200/Solution.java" new file mode 100644 index 0000000..ba37350 --- /dev/null +++ "b/minzino/java/src/main/java/org/example/feb/programmers/\354\231\270\353\262\275_\354\240\220\352\262\200/Solution.java" @@ -0,0 +1,69 @@ +package main.java.org.example.feb.programmers.외벽_점검; + +public class Solution { + int[] weak, dist; + int[][] weak_cases; + int n, answer; + + public int solution(int n, int[] weak, int[] dist) { + weak_cases = new int[weak.length][weak.length]; + this.weak = weak; + this.dist = dist; + this.answer = dist.length+1; + this.n = n; + + + makeWeakCases(); + makeDistCases(new boolean[dist.length], new int[dist.length], 0); + if(answer == dist.length+1) + return -1; + else + return answer; + } + + void makeWeakCases(){ + int[] weak_case = this.weak.clone(); + weak_cases[0] = weak_case.clone(); + for(int i = 1; i < weak.length; i++){ + int temp = weak_case[0]; + for(int j = 1; j < weak.length; j++){ + weak_case[j-1] = weak_case[j]; + } + weak_case[weak.length-1] = temp+n; + weak_cases[i] = weak_case.clone(); + } + } + + void makeDistCases(boolean[] dist_visit, int[] dist_case, int idx){ + if(idx == dist.length){ + for(int[] weak_case: weak_cases) + check(dist_case, weak_case); + } + for(int i = 0; i < dist.length; i++){ + if(!dist_visit[i]){ + dist_visit[i] = true; + dist_case[idx] = dist[i]; + makeDistCases(dist_visit, dist_case, idx+1); + dist_case[idx] = 0; + dist_visit[i] = false; + } + } + } + + void check(int[] dist_case, int[] weak_case){ + int cur = 0, next; + int dist_idx = 0; + while(cur < weak_case.length && dist_idx < dist_case.length){ + next = cur+1; + while(next < weak_case.length && + weak_case[cur] + dist_case[dist_idx] >= weak_case[next]){ + next++; + } + cur = next; + dist_idx++; + } + + if(cur == weak_case.length && dist_idx < answer) + answer = dist_idx; + } +}