-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpalindrome.js
19 lines (16 loc) · 878 Bytes
/
palindrome.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
/*Return true if the given string is a palindrome. Otherwise, return false.
A palindrome is a word or sentence that's spelled the same way both forward and backward, ignoring punctuation, case, and spacing.
Note
You'll need to remove all non-alphanumeric characters (punctuation, spaces and symbols) and turn everything into the same case (lower or upper case) in order to check for palindromes.
We'll pass strings with varying formats, such as "racecar", "RaceCar", and "race CAR" among others.
We'll also pass strings with special symbols, such as "2A3*3a2", "2A3 3a2", and "2_A3*3#A2".
*/
function palindrome(str) {
// Good luck!
const alphaNumStr = str.toLowerCase().replace(/[\W_]*/gi, "");
for (let front=0 ,back=(alphaNumStr.length-1) ;back>=front; front++, back-- ){
if (alphaNumStr[front] != alphaNumStr[back])
return false;
}
return true;
}