2020-10-04 14:22:28 -03:00
|
|
|
/**
|
2023-10-03 23:08:19 +02:00
|
|
|
* What is a palindrome? https://en.wikipedia.org/wiki/Palindrome
|
|
|
|
|
* Receives a string and returns whether it can be rearranged to become a palindrome or not
|
|
|
|
|
* The string can only be a palindrome if the count of ALL characters is even or if the ONLY ONE character count is odd
|
|
|
|
|
* Input is a string
|
|
|
|
|
*
|
|
|
|
|
**/
|
2020-10-04 14:22:28 -03:00
|
|
|
|
2021-10-11 14:07:10 +02:00
|
|
|
export const palindromeRearranging = (str) => {
|
2020-10-04 14:22:28 -03:00
|
|
|
// check that input is a string
|
|
|
|
|
if (typeof str !== 'string') {
|
|
|
|
|
return 'Not a string'
|
|
|
|
|
}
|
|
|
|
|
// Check if is a empty string
|
2023-08-21 15:06:43 -03:00
|
|
|
if (!str) {
|
2020-10-04 14:22:28 -03:00
|
|
|
return 'Empty string'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// First obtain the character count for each character in the string and store it in an object.
|
|
|
|
|
// Filter the object's values to only the odd character counts.
|
|
|
|
|
const charCounts = [...str].reduce((counts, char) => {
|
|
|
|
|
counts[char] = counts[char] ? counts[char] + 1 : 1
|
|
|
|
|
return counts
|
|
|
|
|
}, {})
|
|
|
|
|
// If the length of the resulting array is 0 or 1, the string can be a palindrome.
|
2023-10-03 23:08:19 +02:00
|
|
|
return (
|
|
|
|
|
Object.values(charCounts).filter((count) => count % 2 !== 0).length <= 1
|
|
|
|
|
)
|
2020-10-04 14:22:28 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// testing
|
2021-10-11 14:07:10 +02:00
|
|
|
|
|
|
|
|
// > palindromeRearranging('aaeccrr')
|
|
|
|
|
// true
|
|
|
|
|
|
|
|
|
|
// > palindromeRearranging('leve')
|
|
|
|
|
// false
|