Algorithm/백준

백준 2675 문자열 반복

chbong 2022. 11. 23. 22:08

문제

문자열 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를 출력한다.

 

 

package ch.baekjoon;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

/*
 백준 2675 문자열 반복
 */
public class Algorithm31 {

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(br.readLine());

        int n = Integer.parseInt(st.nextToken());


        for(int i = 0 ; i < n ; i++){
            StringBuilder sb = new StringBuilder();
            st = new StringTokenizer(br.readLine());

            int a = Integer.parseInt(st.nextToken());

            String str = st.nextToken();
            for(int j = 0 ; j < str.length(); j++){
                for(int k = 0; k < a; k++){
                    sb.append(str.charAt(j));
                }
            }
            System.out.println(sb);
        }





    }

}

 

풀이 

첫 n을 받은 후 , n에 대한 반복문을 돌려준다.

그다음 반복할 숫자를 a로 받고 문자열을 str로 받는다.

문자열의 길이 만큼 반복하는 j 반복문에서 a로 받은 반복할 숫자만큼 반복문을 돌려준다.

 append() 함수는 String 에 문자열을 더하는 개념으로 보면 된다.

하여 차곡차곡 쌓은 후 출력하여 해결해주었다.

 

출처 - https://www.acmicpc.net/problem/2675