-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathleetcode-125-ValidPalindrome.js
124 lines (99 loc) · 3.58 KB
/
leetcode-125-ValidPalindrome.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// https://leetcode.com/problems/valid-palindrome/
// p: string
// r boolean
// e:
// Example 1:
// Input: s = "A man, a plan, a canal: Panama"
// Output: true
// Explanation: "amanaplanacanalpanama" is a palindrome.
// Example 2:
// Input: s = "race a car"
// Output: false
// Explanation: "raceacar" is not a palindrome.
// Example 3:
// Input: s = " "
// Output: true
// Explanation: s is an empty string "" after removing non-alphanumeric characters.
// Since an empty string reads the same forward and backward, it is a palindrome.
// recursive O(n) O(n)
var isPalindrome = function (s) {
const alpha = "abcdefghijklmnopqrstuvwxyz0123456789";
const arr = s
.toLowerCase()
.split("")
.filter((c) => alpha.includes(c));
if (!_isPalindrome(arr, 0, arr.length - 1)) return false;
return true;
};
var _isPalindrome = function (arr, i, j) {
if (i > j) return true;
if (arr[i] !== arr[j]) return false;
if (!_isPalindrome(arr, i + 1, j - 1)) return false;
return true;
};
// iterative O(n) O(n)
// var isPalindrome = function(s) {
// let alpha = 'abcdefghijklmnopqrstuvwxyz0123456789';
// let str = ''
// for (let c of s) {
// alpha.includes(c.toLowerCase()) && (str += c.toLowerCase());
// }
// let i = 0, j = str.length - 1;
// while (i < j) {
// if (str[i] !== str[j]) return false
// i++;
// j--;
// }
// return true;
// };
// // Runtime: 89 ms, faster than 66.51% of JavaScript online submissions for Valid Palindrome.
// var isPalindrome = function (s) {
// if (s === " ") return true;
// const alpha = "abcdefghijklmnopqrstuvwxyz0123456789";
// // convert to lowercase and remove non-alphanumeric chars
// let arrS = s
// .toLowerCase()
// .split("")
// .filter((c) => alpha.includes(c));
// for (let i = 0, j = arrS.length - 1; i <= j; i++, j--) {
// // console.log(arrS[i], arrS[j]);
// if (arrS[i] !== arrS[j]) return false;
// }
// return true;
// };
// isPalindrome("A man, a plan, a canal: Panama");
// isPalindrome("race a car");
// isPalindrome("0P");
// // Runtime: 97 ms, faster than 55.15% of JavaScript online submissions for Valid Palindrome.
// var isPalindrome = function (s) {
// if (s === " ") return true;
// const alpha = "abcdefghijklmnopqrstuvwxyz0123456789";
// // convert to lowercase and remove non-alphanumeric chars
// let arrS = s
// .toLowerCase()
// .split("")
// .filter((c) => alpha.includes(c));
// for (let i = 0; i < arrS.length; i++) {
// let j = arrS.length - 1 - i;
// // console.log(arrS[i], arrS[j]);
// if (arrS[i] !== arrS[j]) return false;
// }
// return true;
// };
// ////////////////////////////////////// passed but Runtime: 140 ms, faster than 14.41% of JavaScript online submissions for Valid Palindrome.
// var isPalindrome = function (s) {
// if (s === " ") return true;
// const alpha = "abcdefghijklmnopqrstuvwxyz0123456789";
// // convert to lowercase and remove non-alphanumeric chars
// let arrS = s
// .toLowerCase()
// .split("")
// .filter((c) => alpha.includes(c));
// // split to array, reverse array, join back and compare
// let arrSToString = arrS.join("");
// let arrSReversedToString = arrS.reverse().join("");
// console.log(arrSToString === arrSReversedToString);
// console.log(arrSToString);
// console.log(arrSReversedToString);
// return arrSToString === arrSReversedToString;
// };