mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-07-06 01:18:23 +08:00

* chore: Switch to Node 20 + Vitest * chore: migrate to vitest mock functions * chore: code style (switch to prettier) * test: re-enable long-running test Seems the switch to Node 20 and Vitest has vastly improved the code's and / or the test's runtime! see #1193 * chore: code style * chore: fix failing tests * Updated Documentation in README.md * Update contribution guidelines to state usage of Prettier * fix: set prettier printWidth back to 80 * chore: apply updated code style automatically * fix: set prettier line endings to lf again * chore: apply updated code style automatically --------- Co-authored-by: github-actions <${GITHUB_ACTOR}@users.noreply.github.com> Co-authored-by: Lars Müller <34514239+appgurueu@users.noreply.github.com>
28 lines
816 B
JavaScript
28 lines
816 B
JavaScript
/**
|
|
* @function checkWordOccurrence
|
|
* @description - this function count all the words in a sentence and return an word occurrence object
|
|
* @param {string} str
|
|
* @param {boolean} isCaseSensitive
|
|
* @returns {Object}
|
|
*/
|
|
const checkWordOccurrence = (str, isCaseSensitive = false) => {
|
|
if (typeof str !== 'string') {
|
|
throw new TypeError('The first param should be a string')
|
|
}
|
|
|
|
if (typeof isCaseSensitive !== 'boolean') {
|
|
throw new TypeError('The second param should be a boolean')
|
|
}
|
|
|
|
const modifiedStr = isCaseSensitive ? str.toLowerCase() : str
|
|
|
|
return modifiedStr
|
|
.split(/\s+/) // remove all spaces and distribute all word in List
|
|
.reduce((occurrence, word) => {
|
|
occurrence[word] = occurrence[word] + 1 || 1
|
|
return occurrence
|
|
}, {})
|
|
}
|
|
|
|
export { checkWordOccurrence }
|