JS) BoJ 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를 출력한다.

예제 입력 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