기록하는 개발자

[백준 2675번] 문자열반복 - JAVA 알고리즘 본문

Baekjoon Online Judge

[백준 2675번] 문자열반복 - JAVA 알고리즘

gitseok 2022. 6. 8. 16:05

 

2675번
문제
문자열 S를 입력받은 후에, 각 문자를 R번 반복해 새 문자열 P를 만든 후 출력하는 프로그램을 작성하시오. 즉, 첫 번째 문자를 R번 반복하고, 두 번째 문자를 R번 반복하는 식으로 P를 만들면 된다. S에는 QR Code "alphanumeric" 문자만 들어있다.
QR Code "alphanumeric" 문자는 0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ\$%*+-./: 이다.
입력
첫째 줄에 테스트 케이스의 개수 T(1 ≤ T ≤ 1,000)가 주어진다. 각 테스트 케이스는 반복 횟수 R(1 ≤ R ≤ 8), 문자열 S가 공백으로 구분되어 주어진다. S의 길이는 적어도 1이며, 20글자를 넘지 않는다. 
출력
각 테스트 케이스에 대해 P를 출력한다.
예제 입력 예제 출력
   
2
3 ABC
5 /HTP
AAABBBCCC
/////HHHHHTTTTTPPPPP

 

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.text.ParseException;
import java.util.StringTokenizer;


public class Main {

	public static void main(String[] args) throws IOException, ParseException {
		// TODO Auto-generated method stub
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); // 선언
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); // 선언
		
		int N = Integer.parseInt(br.readLine()); //반복 횟수 지정
		
		for(int i = 0; i<N; i++) { //반복
			
			StringTokenizer st = new StringTokenizer(br.readLine());
			//출력 횟수와 문자열 분리
			int R = Integer.parseInt(st.nextToken());
			String S = st.nextToken();
			
			
			char[] charS = S.toCharArray();//char로 변환
			for(char C : charS) { //char 길이만큼 반복
				for(int j = 0; j<R;j++) { //출력 횟수만큼 반복
					bw.write(C+""); //문자 하나씩 출력
				}
			}
			bw.write("\n"); //줄바꿈처리
		}
		
		
		bw.close();
		br.close();
	}
}

실행 결과

 

개인적으로 정리한 내용을 간단하게 풀어 작성했습니다.
이해가 안가는 부분은 댓글 남겨주시면 설명해드리겠습니다.
Comments