저장을 습관화

프로그래머스 LV.0 문자열이 몇 번 등장하는지 세기 본문

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

프로그래머스 LV.0 문자열이 몇 번 등장하는지 세기

ctrs 2023. 9. 26. 17:41

프로그래머스 LV.0 문자열이 몇 번 등장하는지 세기

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

 

프로그래머스

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

programmers.co.kr

 

1. 문제 명

문자열이 몇 번 등장하는지 세기


2. 문제 설명

문자열 myString과 pat이 주어집니다. 

myString에서 pat이 등장하는 횟수를 return 하는 solution 함수를 완성해 주세요.


3. 제한 사항

  • 1 ≤ myString ≤ 1000
  • 1 ≤ pat ≤ 10


4. 예시

myString pat result
"banana" "ana" 2
"aaaa" "aa" 3


5. 기본 제공 코드

function solution(myString, pat) {
    var answer = 0;
    return answer;
}


6. 제출한 내 답

const solution = (myString, pat) => {
  let arr = [];
  for (i = 0; i <= myString.length - pat.length; i++) {
    arr.push(myString.substr(i, pat.length));
  }
  return arr.filter((v) => v === pat).length;
};

 

6-2. VSC에 작성한 내용

const solution = (myString, pat) => {
  // myString을 pat의 길이로 잘라낸 배열로 만듦
  // ex) "banana" => "ban", "ana", "nan", "ana"
  let arr = [];
  for (i = 0; i <= myString.length - pat.length; i++) {
    arr.push(myString.substr(i, pat.length));
  }
  return arr.filter((v) => v === pat).length;
};

// 테스트
console.log(solution("banana", "ana"));
console.log(solution("aaaa", "aa"));


7. 특이사항

없음


8. 다른 사람이 작성한 답

8-1. 가장 많이 쓰인 풀이법

function solution(myString, pat) {
    let count = 0;
    for (let i = 0; i <= myString.length - pat.length; i++) {
        if (myString.slice(i, i + pat.length) === pat) {
            count++;
        }
    }

    return count;
}