[Bronze II] 문자열 반복 - 2675
2675번: 문자열 반복
문자열 S를 입력받은 후에, 각 문자를 R번 반복해 새 문자열 P를 만든 후 출력하는 프로그램을 작성하시오. 즉, 첫 번째 문자를 R번 반복하고, 두 번째 문자를 R번 반복하는 식으로 P를 만들면 된다
www.acmicpc.net
성능 요약
메모리: 14200 KB, 시간: 144 ms
분류
구현(implementation), 문자열(string)
문제 설명
문자열 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를 출력한다.
답 : split를 통해 공백으로 받은 것을 배열로 잘라주고
첫번째는 int 타입으로, 2번째는 String 타입으로 나눠준다.
r의 길이만큼 p의 String에 있는 문자들을 char로 나눠 한글자씩
출력해주고 한줄마다 한줄을 내려준다.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
for (int i = 0; i < n; i++) {
String[] str = br.readLine().split((" "));
int r = Integer.parseInt(str[0]);
String p = str[1];
for (int j = 0; j < p.length(); j++) {
for (int k = 0; k < r; k++) {
System.out.print(p.charAt(j));
}
}
System.out.println();
}
}
}
'algorithm > 백준' 카테고리의 다른 글
[백준] 숫자의 합 - 11720 Java[자바] (0) | 2022.12.10 |
---|---|
[백준] OX퀴즈 - 8958 Java[자바] (0) | 2022.12.09 |
[백준] 최댓값 - 2562 Java[자바] (0) | 2022.12.09 |
새싹문제 All Clear (0) | 2022.12.08 |
[백준] 검증수 - 2475 Java[자바] (0) | 2022.12.08 |