2021-10-05 12:49:23 +05:30
|
|
|
// Given a sentence, return the most occurring word
|
2021-10-03 22:08:47 +07:00
|
|
|
|
|
|
|
|
/**
|
2021-10-05 12:49:23 +05:30
|
|
|
* @param {string} sentence - the sentence you want to find the most occurring word
|
|
|
|
|
* @returns {string} - the most occurring word
|
2021-10-03 22:08:47 +07:00
|
|
|
*
|
|
|
|
|
* @example
|
|
|
|
|
* - maxWord('lala lili lala'); // lala
|
|
|
|
|
*/
|
|
|
|
|
const maxWord = (sentence = '') => {
|
|
|
|
|
if (typeof sentence !== 'string') {
|
2021-10-05 12:49:23 +05:30
|
|
|
throw new TypeError('the param should be string')
|
2021-10-03 22:08:47 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!sentence) {
|
|
|
|
|
return null
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const words = sentence.split(' ')
|
|
|
|
|
if (words.length < 2) {
|
|
|
|
|
return words[0]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const occurrences = {}
|
2023-10-03 23:08:19 +02:00
|
|
|
words.forEach((word) => {
|
|
|
|
|
occurrences[word.toLocaleLowerCase()] =
|
|
|
|
|
occurrences[word.toLocaleLowerCase()] + 1 || 1
|
2021-10-03 22:08:47 +07:00
|
|
|
})
|
|
|
|
|
|
2023-10-03 23:08:19 +02:00
|
|
|
const max = Object.keys(occurrences).reduce(
|
|
|
|
|
(n, word) => {
|
|
|
|
|
if (occurrences[word] > n.count) {
|
|
|
|
|
return { word, count: occurrences[word] }
|
|
|
|
|
} else {
|
|
|
|
|
return n
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{ word: '', count: 0 }
|
|
|
|
|
)
|
2021-10-03 22:08:47 +07:00
|
|
|
|
|
|
|
|
return max.word
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export { maxWord }
|