🌠 문제

문자열 my_string과 정수 n이 매개변수로 주어질 때, my_string에 들어있는 각 문자를 n만큼 반복한 문자열을 return 하도록 solution 함수를 완성해보세요.

🌠 제한사항

  • 2 ≤ my_string 길이 ≤ 5
  • 2 ≤ n ≤ 10
  • "my_string"은 영어 대소문자로 이루어져 있습니다.

🌠 입출력 예

y_stringnresult

"hello" 3 "hhheeellllllooo"

🌠 입출력 예 설명

입출력 예 #1

  • "hello"의 각 문자를 세 번씩 반복한 "hhheeellllllooo"를 return 합니다.

🧞 풀이

function solution(my_string, n) {
    // 문자열 배열로 만들기
    const arr = my_string.split("");
    
    // 배열에서 map 함수와 repeat 함수를 써서 각 원소 n만큼 반복
    const arr_2 = arr.map(x => x.repeat(n));
    
    // 배열 다시 문자열로 합치기
    const arr_3 = arr_2.join("");
    
    //문자열 리턴
    return arr_3;
}

🌠 문제

정수가 담긴 리스트 num_list가 주어질 때, num_list의 원소 중 짝수와 홀수의 개수를 담은 배열을 return 하도록 solution 함수를 완성해보세요.

🌠 제한사항

  • 1 ≤ num_list의 길이 ≤ 100
  • 0 ≤ num_list의 원소 ≤ 1,000

🌠 입출력 예

[1, 2, 3, 4, 5] [2, 3]
[1, 3, 5, 7] [0, 4]

🌠 입출력 예 설명

입출력 예 #1

  • [1, 2, 3, 4, 5]에는 짝수가 2, 4로 두 개, 홀수가 1, 3, 5로 세 개 있습니다.

입출력 예 #2

  • [1, 3, 5, 7]에는 짝수가 없고 홀수가 네 개 있습니다.

🧞 풀이

function solution(num_list) {
    // map 함수를 통해, 배열 모든 원소 나누기 2
    const num_list2 = num_list.map(x => x % 2);
    
    // 홀수의 갯수 odd에 할당
    const odd = num_list2.filter(x => 1 === x).length;
    
    // 짝수의 갯수 even에 할당
    const even = num_list2.filter(x => 0 === x).length;
    
    // 배열 return
    return [even, odd];
}

🌠 문제

"*"의 높이와 너비를 1이라고 했을 때, "*"을 이용해 직각 이등변 삼각형을 그리려고합니다. 정수 n 이 주어지면 높이와 너비가 n 인 직각 이등변 삼각형을 출력하도록 코드를 작성해보세요.

🌠 제한사항

  • 1 ≤ n ≤ 10

🌠 입출력 예

입력 #1

3

출력 #1

*
**
***

🌠 입출력 예 설명

입출력 예 #1

  • n이 3이므로 첫째 줄에 * 1개, 둘째 줄에 * 2개, 셋째 줄에 * 3개를 출력합니다.

🧞 풀이

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

let input = [];

rl.on('line', function (line) {
    input = line.split(' ');
}).on('close', function () {
    // input으로 받은 값 inputNumber에 할당
    const inputNumber = Number(input[0]);
    
    // 반복문과 repeat()을 통해, 문자열 곱하기를 하여 출력
    for (var i = 1; i <= inputNumber; i++) {
        console.log('*'.repeat(i));
    }
});

🌠 문제

문자열 my_string이 매개변수로 주어집니다. my_string을 거꾸로 뒤집은 문자열을 return하도록 solution 함수를 완성해주세요.

🌠 제한사항

  • 1 ≤ my_string의 길이 ≤ 1,000

🌠 입출력 예

"jaron" "noraj"
"bread" "daerb"

🌠 입출력 예 설명

입출력 예 #1

  • my_string이 "jaron"이므로 거꾸로 뒤집은 "noraj"를 return합니다.

입출력 예 #2

  • my_string이 "bread"이므로 거꾸로 뒤집은 "daerb"를 return합니다.

🧞 풀이

function solution(my_string) {
    // split으로 문자열을 한 글자씩 쪼개 배열을 만들고, 배열을 뒤집기
    const reverse_string_array = my_string.split("").reverse();
    // 해당 배열을 join으로 다시 합쳐 문자열 만들기
    const answer = reverse_string_array.join("");
    // 문자열 리턴
    return answer;
}

🌠 문제

정수가 들어 있는 배열 num_list가 매개변수로 주어집니다. num_list의 원소의 순서를 거꾸로 뒤집은 배열을 return하도록 solution 함수를 완성해주세요.

🌠 제한사항

  • 1 ≤ num_list의 길이 ≤ 1,000
  • 0 ≤ num_list의 원소 ≤ 1,000

🌠 입출력 예

[1, 2, 3, 4, 5] [5, 4, 3, 2, 1]
[1, 1, 1, 1, 1, 2] [2, 1, 1, 1, 1, 1]
[1, 0, 1, 1, 1, 3, 5] [5, 3, 1, 1, 1, 0, 1]

🌠 입출력 예 설명

입출력 예 #1

  • num_list가 [1, 2, 3, 4, 5]이므로 순서를 거꾸로 뒤집은 배열 [5, 4, 3, 2, 1]을 return합니다.

입출력 예 #2

  • num_list가 [1, 1, 1, 1, 1, 2]이므로 순서를 거꾸로 뒤집은 배열 [2, 1, 1, 1, 1, 1]을 return합니다.

입출력 예 #3

  • num_list가 [1, 0, 1, 1, 1, 3, 5]이므로 순서를 거꾸로 뒤집은 배열 [5, 3, 1, 1, 1, 0, 1]을 return합니다.

🧞 풀이

function solution(num_list) {
    
    // 새로운 배열 생성
    const new_list = [];
    
    // 새로운 배열에 num_list 인덱스 거꾸로 하나씩 push
    for (var i = num_list.length - 1; i >= 0; i --) {
      new_list.push(num_list[i]);  
    }
    
    // 새로운 배열 출력
    return new_list;
}

🌠 문제

머쓱이는 40살인 선생님이 몇 년도에 태어났는지 궁금해졌습니다. 나이 age가 주어질 때, 2022년을 기준 출생 연도를 return 하는 solution 함수를 완성해주세요.

🌠 제한사항

  • 0 < age ≤ 120
  • 나이는 태어난 연도에 1살이며 1년마다 1씩 증가합니다.

🌠 입출력 예

40 1983
23 2000

🌠 입출력 예 설명

입출력 예 #1

  • 2022년 기준 40살이므로 1983년생입니다.

입출력 예 #2

  • 2022년 기준 23살이므로 2000년생입니다.

 


🧞 풀이

function solution(age) {
    const y = 2022 - age + 1;
    return y;
}

// 나이 계산이 헷갈리면, 테스트 케이스를 보면서 수정해가면 된다.

🌠 문제

머쓱이는 추운 날에도 아이스 아메리카노만 마십니다. 아이스 아메리카노는 한잔에 5,500원입니다. 머쓱이가 가지고 있는 돈 money가 매개변수로 주어질 때, 머쓱이가 최대로 마실 수 있는 아메리카노의 잔 수와 남는 돈을 순서대로 담은 배열을 return 하도록 solution 함수를 완성해보세요.

🌠 제한사항

  • 0 < money ≤ 1,000,000

🌠 입출력 예

5,500 [1, 0]
15,000 [2, 4000]

🌠 입출력 예 설명

입출력 예 #1

  • 5,500원은 아이스 아메리카노 한 잔을 살 수 있고 잔돈은 0원입니다.

입출력 예 #2

  • 15,000원은 아이스 아메리카노 두 잔을 살 수 있고 잔돈은 4,000원입니다.

🧞 풀이

function solution(money) {
    const q = parseInt(money / 5500);
    const r = money % 5500;
    return [q, r]
}

🌠 문제

머쓱이네 옷가게는 10만 원 이상 사면 5%, 30만 원 이상 사면 10%, 50만 원 이상 사면 20%를 할인해줍니다.
구매한 옷의 가격 price가 주어질 때, 지불해야 할 금액을 return 하도록 solution 함수를 완성해보세요.

🌠 제한사항

  • 10 ≤ price ≤ 1,000,000
    • price는 10원 단위로(1의 자리가 0) 주어집니다.
  • 소수점 이하를 버린 정수를 return합니다.

🌠 입출력 예

150,000 142,500
580,000 464,000

🌠 입출력 예 설명

입출력 예 #1

  • 150,000원에서 5%를 할인한 142,500원을 return 합니다.

입출력 예 #2

  • 580,000원에서 20%를 할인한 464,000원을 return 합니다.

🧞 풀이

// 소수점 이하를 버린 정수를 return => parseInt를 써서, 소수점 이하를 버리자.

function solution(price) {
    if (price >= 500000) {
        return parseInt(price * 0.8);
    } else if (price >= 300000) {
        return parseInt(price * 0.9);
    } else if (price >= 100000) {
        return parseInt(price * 0.95);
    } else {
        return price;
    }
}

+ Recent posts