백준 알고리즘 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를 출력한다.

문제풀이

먼저 맨 첫번째줄은 몇개의 라인을 입력받는지 문자열이 넘어오고 , 그 다음부터는 앞에는 반복되는 숫자의 값, 뒤에는 반복될 문자열이 주어진다.

풀기위해 먼저 입력값을 가공했다.

[
    {
        loop:숫자,
        text:문자열
    },
    {
        loop:숫자,
        text:문자열
    },
]

위와 같은 형태로 만들어주었다.

그다음 loop를 돌면서 해당 object에 접근해서 각 텍스트 위치에 loop만큼 문자열을 반복하면서 += 해주었다.

const readline = require("readline")

const rl = readline.createInterface({
    input: process.stdin,
    output: process.stdout,
})

const input = []

rl.on("line", function(line) {
    input.push(line.toString().split(' '))
}).on("close", function() {
    input.shift()
    let result = ''

    const obj = input.map((item,idx)=>{
        return {
            loop: Number(item[0]),
            text: item[1]
        }
    })

    obj.map((item) => {
        for(let i = 0; i < item['text'].length; i++){
            for(let j = item['loop']; j > 0; j--){
                result += item['text'][i]
            }
        }
        result += '\n'
    })

    console.log(result)

    process.exit();
})

input.shift()를 안빼서 계속 런타입에러 나서 고생을 했다. 백준은 문제 푸는것도 푸는거지만 입력값 가공이 시간이 더 오래간다.

Leave a Comment