공log/[P&B]

[P&B] #54 BAEKJOON 2675

ming_OoO 2023. 9. 16. 11:59
728x90

백준 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를 출력한다.

 

나의 문제 풀이 코드

import java.util.*;
import java.io.*;
public class bj2675 {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

        int T = Integer.parseInt(br.readLine());
        String[] str = new String[T];
        for (int i = 0; i < T; i++) {
            StringTokenizer st = new StringTokenizer(br.readLine());
            int R = Integer.parseInt(st.nextToken());
            String S = st.nextToken();
            String r = "";
            for (int j = 0; j < S.length(); j++) {
                for (int k = 0; k < R; k++) {
                    r += S.charAt(j);
                }
                str[i] = r;
            }
        }

        for (String s :
                str) {
            bw.write(s+"\n");
        }
        bw.flush();
    }
}

 

문제 풀이 코멘트

for 루프를 사용하여 각 테스트 케이스를 처리합니다.

  • StringTokenizer를 사용하여 테스트 케이스의 입력을 분리합니다.
  • R은 문자를 반복할 횟수, S는 반복할 문자열입니다.
  • r이라는 빈 문자열을 생성하여, 각 문자를 R만큼 반복하여 r에 추가합니다.
  • 이렇게 생성된 r 문자열을 str[i] 배열에 저장합니다.
728x90

'공log > [P&B]' 카테고리의 다른 글

[P&B] #56 BAEKJOON 2908  (0) 2023.09.17
[P&B] #55 BAEKJOON 1152  (0) 2023.09.16
[P&B] #53 BAEKJOON 11720  (0) 2023.09.16
[P&B] #52 BAEKJOON 11654  (0) 2023.09.16
[P&B] #51 BAEKJOON 10811  (0) 2023.09.16