일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- php 프로그래밍 입문 연습문제
- 최단 경로
- 스프링
- php
- spring
- 플러터 개발환경 설정
- 페이코 친구코드
- 파이썬
- 한정 분기
- php 프로그래밍 입문 솔루션
- 배열
- php 프로그래밍 입문 문제풀이
- php 프로그래밍 입문 3판
- 자바 스프링
- 페이코 초대코드
- Java
- Flutter
- 자바
- C언어
- programmers
- php 프로그래밍 입문
- 플러터
- php 프로그래밍 입문 예제
- 백준
- php 프로그래밍
- JAVA SPRING
- SWEA
- 페이코 추천인코드
- C
- 페이코 추천인
Archives
- Today
- Total
01-22 13:27
ImJay
[SWEA/Java] 1228. 암호문 1 본문
반응형
[SWEA/Java] 1228. 암호문 1
풀이
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 닫기
}
}
반응형
'SW Expert Academy > D3' 카테고리의 다른 글
[SWEA/Java] 6808. 규영이와 인영이의 카드게임 (0) | 2024.04.18 |
---|---|
[SWEA/Java] 1225. 암호생성기 (0) | 2024.02.04 |
[SWEA/Java] 6808. 규영이와 인영이의 카드게임 (0) | 2024.02.04 |
[SWEA/Java] 5215. 햄버거 다이어트 (0) | 2024.02.04 |
[SWEA/Java] 7964. 부먹왕국의 차원 관문 (0) | 2024.01.29 |
Comments