• 문제 링크
4881번: 자리수의 제곱
89, 145, 42, 20, 4, 16, 37, 58 사이클 1 사이클
www.acmicpc.net
• 풀이 코드
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.List;
public class Main {
public static void main(String[] args) throws IOException {
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringBuilder sb = new StringBuilder();
int a, b;
while ((a = read()) != 0 && (b = read()) != 0) {
sb.append(a).append(" ").append(b).append(" ");
List<Integer> A = new ArrayList<>(), B = new ArrayList<>();
do A.add(a); while (!A.contains(a = generate(a)));
do B.add(b); while (!B.contains(b = generate(b)));
sb.append(compare(A, B)).append("\n");
}
bw.write(sb.toString());
bw.flush();
}
private static int generate(int n) {
int sum = 0;
do sum += (n % 10) * (n % 10); while ((n /= 10) > 0);
return sum;
}
private static int compare(List<Integer> A, List<Integer> B) {
int min = Integer.MAX_VALUE;
for (int i = 0; i < A.size(); i++)
for (int j = 0, a = A.get(i); j < B.size(); j++)
if (a == B.get(j)) min = Math.min(min, i + j);
return min != Integer.MAX_VALUE ? min + 2 : 0;
}
private static int read() throws IOException {
int c, n = System.in.read() & 15;
while ((c = System.in.read()) > 32) n = (n << 3) + (n << 1) + (c & 15);
return n;
}
}
'Problem Solving > Baekjoon' 카테고리의 다른 글
[백준] 3982 Soccer Bets - Data Structure / Java (0) | 2023.11.05 |
---|---|
[백준] 18294 Biodiversity - Data Structure / Java (0) | 2023.11.04 |
[백준] 10105 Assigning Partners - Data Structure / Java (0) | 2023.11.02 |
[백준] 9728 Pair Sum - Data Structure / Java (0) | 2023.11.01 |
[백준] 13211 Passport Checking - Data Structure / Java (0) | 2023.10.31 |
댓글