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 |