-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathindex.js
42 lines (38 loc) · 873 Bytes
/
index.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
/**
* Problem: https://leetcode.com/problems/palindrome-partitioning/description/
*/
/**
* @param {string} s
* @return {string[][]}
*/
var partition = function(s) {
var result = [];
var cache = {};
var tmp;
var isPalin = function (start, end) {
if (cache[start + ',' + end] === undefined) {
for (;start <= end; ++start, --end) {
if (s[start] !== s[end]) break;
}
cache[start + ',' + end] = start > end;
}
return cache[start + ',' + end];
};
var dfs = function (start, arr) {
if (start === s.length) {
result.push(arr);
} else {
var str = '';
for (var i = start, l = s.length; i < l; ++i) {
str += s[i];
if (isPalin(start, i)) {
tmp = arr.slice();
tmp.push(str);
dfs(i + 1, tmp);
}
}
}
};
dfs(0, []);
return result;
};