본문 바로가기
Problem Solving/Baekjoon

[백준] 4881 자리수의 제곱 - Data Structure / Java

by graycode 2023. 11. 3.

 문제 링크

 

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;
    }

}

댓글