반응형
Notice
Recent Posts
Recent Comments
Link
«   2024/05   »
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
Archives
Today
Total
05-19 00:03
관리 메뉴

ImJay

[SWEA/Java] 4366. 정식이의 은행 업무 본문

SW Expert Academy/D4

[SWEA/Java] 4366. 정식이의 은행 업무

ImJay 2024. 4. 16. 14:18
반응형

[SWEA/Java] 4366. 정식이의 은행 업무

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com


문제 해석

이 문제는 정식이가 잘못 기억하는 2진수와 3진수 표현으로부터 원래의 송금 금액을 추측해내는 것이다. 정식이는 각 숫자 표현에서 한 자리씩 오류를 범했다는 것을 알고 있다. 문제 해결을 위해 2진수의 각 자리를 바꿔 가며 해당 값을 10진수로 계산하고, 이를 3진수의 각 자리를 변형시켜 얻은 값들과 비교하여 일치하는 순간을 찾아야 한다.

풀이 과정

  1. 입력 처리: 각 테스트 케이스 별로 2진수와 3진수를 입력 받는다. 이들을 정수 배열로 변환하여 저장한다.
  2. 2진수 변형 및 계산: 2진수의 각 자리를 바꿔가며 10진수로 변환한다.
  3. 3진수 변형 및 계산: 3진수의 각 자리를 바꿔가며 10진수로 변환한다. 이 때, 2진수에서 변환된 10진수 값과 일치하는지 검사한다.
  4. 일치 검사: 일치하는 값이 발견되면 해당 값을 결과로 설정하고, 검색을 종료한다.

코드

package edu.ssafy.im.SWEA.D4.No4366;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;

public class Solution {
    int[] n, m;  // n은 2진수, m은 3진수를 저장하는 배열
    int ans;  // 추측된 송금 금액

    public static void main(String[] args) throws NumberFormatException, IOException {
        new Solution().io();
    }

    private void io() throws NumberFormatException, IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        StringBuilder sb = new StringBuilder();

        int testCase = Integer.parseInt(br.readLine());

        for (int t = 1; t <= testCase; t++) {
            String s = br.readLine();
            n = new int[s.length()];
            for (int i = s.length() - 1; i >= 0; i--) {
                n[s.length() - 1 - i] = s.charAt(i) - '0';  // 2진수 역순으로 저장
            }

            s = br.readLine();
            m = new int[s.length()];
            for (int i = s.length() - 1; i >= 0; i--) {
                m[s.length() - 1 - i] = s.charAt(i) - '0';  // 3진수 역순으로 저장
            }

            sol();

            sb.append("#").append(t).append(" ").append(ans).append("\n");
        }

        bw.write(sb.toString());
        bw.flush();
        bw.close();
    }

    private void sol() {
        for (int i = 0; i < n.length; i++) {
            n[i] = n[i] == 1 ? 0 : 1;  // 2진수 자리 바꾸기
            int binarySum = binaryToNum();  // 변형된 2진수를 10진수로 변환
            for (int j = 0; j < m.length; j++) {
                int tmp = m[j];
                for (int k = 0; k < 3; k++) {
                    if (k != tmp) {
                        m[j] = k;  // 3진수 자리 바꾸기
                        int trinarySum = trinaryToNum();  // 변형된 3진수를 10진수로 변환
                        if (binarySum == trinarySum) {  // 10진수 값이 일치하면
                            ans = binarySum;  // 정답 저장
                            return;  // 반복 종료
                        }
                    }
                }
                m[j] = tmp;  // 원래 3진수 값 복원
            }
            n[i] = n[i] == 1 ? 0 : 1;  // 원래 2진수 값 복원
        }
    }
    
    private int binaryToNum() {
        int sum = n[0];  // 가장 낮은 자리 값
        for (int i = 1; i < n.length; i++) {
            sum += n[i] * Math.pow(2, i);  // 2진수를 10진수로 계산
        }
        return sum;
    }

    private int trinaryToNum() {
        int sum = m[0];  // 가장 낮은 자리 값
        for (int i = 1; i < m.length; i++) {
            sum += m[i] * Math.pow(3, i);  // 3진수를 10진수로 계산
        }
        return sum;
    }
}

시간 복잡도 분석

이 알고리즘의 시간 복잡도는 O(n * m)이다. 여기서 n은 2진수의 길이, m은 3진수의 길이를 나타낸다. 각 2진수 자리마다 모든 3진수 자리를 변경하며 검사한다.

느낀점

이 문제는 복잡한 숫자 변환과 조건 검사를 통해 문제를 해결해야 하므로, 시스템적인 접근과 철저한 디버깅이 필요하다. 다양한 진법 사이의 변환과 조건 검사를 통해, 복잡한 문제를 해결하는 데 있어서 프로그래밍 능력을 강화하는 좋은 기회가 되었다.

반응형
Comments