Computer >> 컴퓨터 >  >> 프로그램 작성 >> JavaScript

JavaScript의 문장에서 n개의 가장 빈번한 단어 찾기

<시간/>

이 질문의 목적을 위해 우리는 문장을 영어 알파벳과 구두점을 포함하는 문자열로 정의하고 단어는 공백으로 결합된 해당 문장의 하위 문자열입니다.

문장 문자열 str을 첫 번째 인수로, 숫자 num을 두 번째 인수로 취하는 JavaScript 함수를 작성해야 합니다. 함수는 먼저 문장에서 각 단어의 빈도를 계산한 다음 빈도 감소에 따라 배치된 가장 빈번한 num개의 단어를 포함하는 길이 num의 배열을 반환해야 합니다.

예를 들어 -

입력된 문장과 숫자가 -

인 경우
const str = 'i am a good coder and i know that i can solve a problem';
const num = 2;

그러면 출력은 다음과 같아야 합니다. -

const output = ['i', 'a'];

'i'는 3번 나타나는 반면 'a'는 배열에서 2번 나타나며 문자열에서 가장 자주 나오는 2개의 단어이기 때문입니다.

예시

이에 대한 코드는 -

const str = 'i am a good coder and i know that i can solve a problem';
const num = 2;
const findMostFrequent = (str = '', num = 1) => {
   const strArr = str.split(' ');
   const map = {};
   strArr.forEach(word => {
      if(map.hasOwnProperty(word)){
         map[word]++;
      }else{
         map[word] = 1;
      }
   });
   const frequencyArr = Object.keys(map).map(key => [key, map[key]]);
   frequencyArr.sort((a, b) => b[1] - a[1]);
   return frequencyArr.slice(0, num).map(el => el[0]);
};
console.log(findMostFrequent(str, num));

출력

콘솔의 출력은 -

[ 'i', 'a' ]