Preface: Why strengthen the algorithm?
Programming language thousands of, update iteration is changing with each new day, stripping the language of programming language itself, extracted is the data structure + algorithm only put energy on the most basic, the lowest level of knowledge, hard practice in order to respond to all changes, in order to improve their hard power.
Write a function to find the longest public prefix in an array of strings. Returns the empty string “” if no public prefix exists.
Example 1
Input:"flower"."flow"."flight"] output:"fl"
Copy the code
Example 2
Input:"dog"."racecar"."car"] output:""
Copy the code
JavaScript solution
Compares strings one time from front to back to get the common prefix
Time complexity: O(s) is the sum of the number of characters in all strings
Space complexity: O(1)
var longestCommonPrefix = function(strs) {
if (strs === null || strs.length === 0) return "";
let prevs = strs[0]
for(let i = 1; i < strs.length; i++) {
let j = 0
for(; j < prevs.length && j < strs[i].length; j++) {
if(prevs.charAt(j) ! == strs[i].charAt(j))break
}
prevs = prevs.substring(0, j)
if(prevs === "") return ""
}
return prevs
};
Copy the code
TypeScript solution
1. The longest prefixes are the same, so run through the shortest element in the array: x. 2. Take the element x with the shortest length to determine whether other elements start with it. If so, return x, and the program ends. 3. If there is one that does not start with it, the judgment is complete. Then take the length of the former X. length-1 of x and repeat step 2. 3. If there is one that does not start with it, the judgment ends, and then take the length of the former X. length-2 of x, and repeat step 2. . 4. If the length is 0, prove that there is no common prefix, return an empty string, the program ends
function longestCommonPrefix(strs: string[]) :string {
if(! strs.length) {return "";
}
let min = strs[0];
strs.forEach(item= > {
if(item.length < min.length) { min = item; }});const minArr = min.split("");
for (let i = minArr.length; i > 0; i--) {
let pre = minArr.slice(0, i).join("");
let has = 0;
for (let j = 0; j < strs.length; j++) {
if (strs[j].startsWith(pre)) {
has++;
} else {
break; }}if (has === strs.length) {
returnpre; }}return "";
};
Copy the code