반응형
Notice
Recent Posts
Recent Comments
Link
«   2025/01   »
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
01-22 13:27
관리 메뉴

ImJay

[SWEA/Java] 1228. 암호문 1 본문

SW Expert Academy/D3

[SWEA/Java] 1228. 암호문 1

ImJay 2024. 2. 5. 21:33
반응형

[SWEA/Java] 1228. 암호문 1

 

 

SW Expert Academy

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

swexpertacademy.com


풀이

import java.io.*;
import java.util.LinkedList;
import java.util.StringTokenizer;

public class Solution {
    public static void main(String[] args) throws IOException {
        new Solution().io(); // Main 메소드에서 프로그램 실행을 위해 io() 메소드 호출
    }

    private void io() throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); // 입력을 위한 BufferedReader 선언
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); // 출력을 위한 BufferedWriter 선언
        StringBuilder sb = new StringBuilder(); // 출력 결과를 저장할 StringBuilder 선언

        for (int t = 1; t <= 10; t++) { // 10개의 테스트 케이스 반복
            int n = Integer.parseInt(br.readLine()); // 원본 암호문의 길이를 입력 받음
            LinkedList<Integer> linkedList = new LinkedList<>(); // LinkedList 선언 (원본 암호문을 저장할 자료구조)
            StringTokenizer st = new StringTokenizer(br.readLine()); // 원본 암호문을 공백을 기준으로 분리하기 위한 StringTokenizer 생성
            for (int i = 0; i < n; i++) { // 원본 암호문의 길이만큼 반복하여 LinkedList에 원소 추가
                linkedList.add(Integer.parseInt(st.nextToken())); // StringTokenizer를 통해 분리된 문자열을 정수로 변환하여 LinkedList에 추가
            }
            n = Integer.parseInt(br.readLine()); // 명령어의 개수를 입력 받음
            st = new StringTokenizer(br.readLine()); // 명령어를 공백을 기준으로 분리하기 위해 StringTokenizer 재사용
            for (int i = 0; i < n; i++) { // 명령어의 개수만큼 반복
                st.nextToken(); // I 문자열을 건너뜀
                int idx = Integer.parseInt(st.nextToken()); // 삽입할 위치를 나타내는 인덱스를 입력 받음
                int m = Integer.parseInt(st.nextToken()); // 삽입할 숫자의 개수를 입력 받음
                for (int j = 0; j < m; j++) { // 삽입할 숫자의 개수만큼 반복하여 LinkedList에 삽입
                    linkedList.add(idx + j, Integer.parseInt(st.nextToken())); // 인덱스 위치에 숫자를 삽입
                }
            }
            sb.append("#").append(t).append(" "); // 결과를 StringBuilder에 추가
            for (int i = 0; i < 10; i++) { // 수정된 결과의 처음 10개 숫자를 출력하기 위해 반복
                sb.append(linkedList.get(i)).append(" "); // LinkedList에서 값을 가져와 StringBuilder에 추가
            }
            sb.append("\n"); // 테스트 케이스마다 결과를 구분하기 위해 줄 바꿈 문자 추가
        }

        bw.write(sb.toString()); // StringBuilder에 저장된 결과를 BufferedWriter를 통해 출력
        bw.flush(); // 버퍼를 비우고 출력
        bw.close(); // BufferedWriter 닫기
    }
}
반응형
Comments