-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcommon_prefix.js
68 lines (60 loc) · 1.71 KB
/
common_prefix.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
// https://leetcode.com/problems/longest-common-prefix/description/
// 14. Longest Common Prefix
/**
* @param {string[]} strs
* @return {string}
*/
var longestCommonPrefix = function(strs) {
if (strs.length < 2) return ""
for (let i=0; i<strs[0].length; i++) {
for (let j=1; j<strs.length; j++) {
if (strs[j].length<=i || strs[j][i] != strs[0][i]) return strs[0].slice(0,i);
}
}
return strs[0];
};
console.log("Longest Common Prefix")
console.log(longestCommonPrefix(["flower","flow","flight"]))
// # Output: "fl"
console.log(longestCommonPrefix(["dog","racecar","car"]))
// Output: ""
console.log(longestCommonPrefix(["flow","flow","flow"]))
// Output: "flow"
console.log(longestCommonPrefix(["dog"]))
// Output: ""
// ########################
// https://leetcode.com/problems/find-the-length-of-the-longest-common-prefix/description/
// 3043. Find the Length of the Longest Common Prefix
/**
* @param {number[]} arr1
* @param {number[]} arr2
* @return {number}
*/
var longestCommonPrefixAtLeastOne = function(arr1, arr2) {
if (arr1.length < 1 || arr2.length < 1) return 0;
let acc = new Set();
for (let x of arr1){
while (x > 0){
acc.add(x);
x = Math.trunc(x / 10);
}
}
let out = 0
for(let x of arr2){
while (x > 0 || x > 10 ** out){
if (acc.has(x)){
let str = String(x);
out = Math.max(out, str.length);
};
x = Math.trunc(x / 10);
}
}
return out;
};
console.log("Find the Length of the Longest Common Prefix")
console.log(longestCommonPrefixAtLeastOne([1,10,100], [1000, 1]))
// # Output: 3
console.log(longestCommonPrefixAtLeastOne([1,2,3], [4,4,4]))
// # Output: 0
console.log(longestCommonPrefixAtLeastOne([1,2,3], []))
// # Output: 0