저장을 습관화

프로그래머스 LV.0 k의 개수 본문

코딩 테스트/프로그래머스 - 자바스크립트

프로그래머스 LV.0 k의 개수

ctrs 2023. 9. 24. 03:13

프로그래머스 LV.0 k의 개수

https://school.programmers.co.kr/learn/courses/30/lessons/120887

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

1. 문제 명

k의 개수


2. 문제 설명

1부터 13까지의 수에서, 1은 1, 10, 11, 12, 13 이렇게 총 6번 등장합니다. 정수 i, j, k가 매개변수로 주어질 때, i부터 j까지 k가 몇 번 등장하는지 return 하도록 solution 함수를 완성해주세요.


3. 제한 사항

  • 1 ≤ i < j ≤ 100,000
  • 0 ≤ k ≤ 9


4. 예시

i j k result
1 13 1 6
10 50 5 5
3 10 2 0


5. 기본 제공 코드

function solution(i, j, k) {
    var answer = 0;
    return answer;
}


6. 제출한 내 답

const solution = (i, j, k) => {
  let arr = [];
  for (n = i; n <= j; n++) {
    if ((n + "").includes(k)) arr.push(n + "");
  }
  return arr
    .join("")
    .split("")
    .filter((v) => +v === k).length;
};

 

6-2. VSC에 작성한 내용

const solution = (i, j, k) => {
  let arr = [];
  for (n = i; n <= j; n++) {
    if ((n + "").includes(k)) arr.push(n + "");
  }
  return arr
    .join("")
    .split("")
    .filter((v) => +v === k).length;
};

// 테스트
console.log(solution(1, 13, 1));
console.log(solution(10, 50, 5));
console.log(solution(3, 10, 2));


7. 특이사항

저번에 배웠던 n부터 m까지의 배열 만드는 방법을 써보려고 했는데 잘 안되더라

Array(n).fill().map((_, i) => i + 1));

map 안에 쓰이는 매개변수를 밖에서 가져올 수는 없었다.

 


8. 다른 사람이 작성한 답

8-1. split의 여집합을 이용한 방법

function solution(i, j, k) {
    let a ='';
    for(i;i<=j;i++){
        a += i;
    }

    return a.split(k).length-1;
}

아..

 

8-2. Array를 사용한 배열 만드는 법

function solution(i, j, k) {
    let str = Array(j - i + 1).fill(i).map((v, i) => v + i).join('')
    return Array.from(str).filter(t => +t === k).length;
}

아 이렇게 만들면 되는구나

// 1부터 10으로 이루어진 정수 배열을 만든다고 할 때

let i = 1
let j = 10

console.log(Array()) // []

console.log(Array(j - i)) // [ <9 empty items> ]

console.log(Array(j - i).fill(i)) // [ 1, 1, 1, 1, 1, 1, 1, 1, 1 ]

console.log(Array(j - i).fill(i).map((v, i) => v + i) // [ 1, 2, 3, 4, 5, 6, 7, 8, 9 ]

console.log(Array(j - i + 1).fill(i).map((v, i) => v + i) // [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ]