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