반응형
문제
문자열 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 ABC 5 /HTP
예제 출력 1 복사
AAABBBCCC /////HHHHHTTTTTPPPPP
발상 자체는 어렵지 않다
// 입력
const fs = require('fs');
const filePath = process.platform === 'linux'? '/dev/stdin' : './input.txt';
let input = fs.readFileSync(filePath).toString().split('\n');
let cases = parseInt(input.shift());
// cases 숫자만큼 반복해서 제출값을 만듦
for (let i = 0; i < cases; i++) {
let tempArr = input[i].split(' ');
let multi = parseInt(tempArr.shift());
// 제출값을 만들 반복문
let answer = []; // 제출값을 넣을 배열
for (let j = 0; j < tempArr[0].length; j++) {
// multi에 넣은 숫자만큼 문자를 출력하므로 반복문을 또 만든다
for (let k = 0; k < multi; k++) {
answer += tempArr[0][j]; // 출력하기 편하도록 + 사용
}
}
// 출력 후 재반복
console.log(answer);
}
하지만 무려 3중반복을 해서 너무 느려지지 않을까 생각했는데 그렇지는 않았다.
반응형
'Algorithm > Baekjoon' 카테고리의 다른 글
Node.js) BoJ 1021 회전하는 큐 (0) | 2022.03.09 |
---|---|
JS) BoJ 8958 OX퀴즈 (0) | 2021.08.01 |
JS) BoJ 1157 단어 공부 (0) | 2021.07.31 |
JS) BoJ 1929 소수 구하기/ 에라토스테네스의 체 (0) | 2021.07.31 |
JS) BoJ 1978 소수 찾기 (0) | 2021.07.31 |