[BOJ 2675] 문자열 반복
Baekjoon Online Judge 2675(Java 11)
[문자열 반복] 문제 풀이
[BOJ 2675] 문자열 반복
시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
---|---|---|---|---|---|
1 초 | 128 MB | 287067 | 145282 | 122576 | 50.274% |
문제
문자열 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를 출력한다.
예제
1
2
3
4
// 입력
2
3 ABC
5 /HTP
1
2
3
// 출력
AAABBBCCC
/////HHHHHTTTTTPPPPP
출처
- ICPC > Regionals > North America > Greater New York Region > 2011 Greater New York Programming Contest A번
알고리즘 분류
제출
내 제출
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import java.io.*;
import java.util.*;
public class Main {
public static void solution() throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int t = Integer.parseInt(br.readLine()); // 테스트 케이스 개수
for (int i = 0; i < t; i++) { // t 만큼 반복
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
int r = Integer.parseInt(st.nextToken()); // 문자 반복횟수
char[] str = st.nextToken().toCharArray(); // 입력받은 문자열 -> char 배열 화
String answer = "";
for (int j = 0; j < str.length; j++) {
for (int k = 0; k < r; k++) { // r만큼 반복
answer += str[j];
}
}
bw.write(answer + "\n");
}
bw.flush();
bw.close();
br.close();
}
public static void main(String[] args) throws IOException {
solution();
}
}
런타임 | 메모리 |
---|---|
136 ms | 16248 KB |
Reference
This post is licensed under CC BY 4.0 by the author.