728x90
반응형
문제
문자열 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글자를 넘지 않는다.
2
3 ABC
5 /HTP
출력
각 테스트 케이스에 대해 P를 출력한다.
AAABBBCCC
/////HHHHHTTTTTPPPPP
내 풀이
import java.io.BufferedReader;
import java.io.InputStreamReader;
//문자열 반복(2675)
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int T = Integer.parseInt(br.readLine()); //테스트케이스 T (예제 : 2)
String[] ans = new String[T]; //sysout할 문자열의 배열
for(int i=0; i<T; i++) {
String[] A = br.readLine().split(" "); //띄어쓰기로 문자를 나눔
int R = Integer.parseInt(A[0]); //첫 번째 문자를 숫자로 반환 (예제 : 3, 5)
String[] S = A[1].split(""); //두 번째 문자열을 문자 배열로 나눔 (예제 : ABC, /HTP)
ans[i] = ""; //ans[i] 빈 문자열로 초기화
for(int j=0; j<S.length; j++) {
for(int k=0; k<R; k++) {
ans[i] += S[j]; //각 문자열의 문자를 R만큼 붙임. (AAABBBCCC)
}
}
}
for(int i=0; i<T; i++) {
System.out.println(ans[i]);
}
}
}
약 20문제를 풀었다. Scanner말고 BufferedReader로 푸는 연습을 쭈욱 해왔고 이제서야 좀 감이 잡히는 거 같아서 기분 굿!
반응형
'개발 > 코테 준비' 카테고리의 다른 글
자바 백준 2908 - 상수 (0) | 2021.10.10 |
---|---|
자바 백준 1152 - 단어의 개수 (0) | 2021.10.10 |
자바 백준 2562 - 최댓값 :: 배열 복사(깊은 복사와 얕은 복사) (0) | 2021.09.15 |
[자바] 프로그래머스 1단계 - 평균 구하기 (0) | 2021.03.02 |
[자바] 프로그래머스 1단계 - 짝수와 홀수 (0) | 2021.03.02 |
댓글