How to Find the Longest Common Prefix in JavaScript

The longest common prefix of an array of strings is the initial segment that is common to all strings in the array. In JavaScript, this can be computed through string comparison and iteration techniques.

Understanding the problem

To find the longest common prefix, we compare the characters of each string at the same index until a mismatch is found. This operation is performed iteratively or recursively, stopping when the shortest string's length is reached or a differing character is encountered.

Implementing a solution

Here's an approach to solving this problem using JavaScript:

function findLongestCommonPrefix(strs) { if (!strs.length) return ''; let prefix = strs[0]; for (let i = 1; i < strs.length; i++) { while (strs[i].indexOf(prefix) !== 0) { prefix = prefix.substring(0, prefix.length - 1); if (!prefix) return ''; } } return prefix; }

How the solution works

  1. Initialize the prefix to the first string in the array.
  2. Iterate over the array of strings.
  3. Use the indexOf function to check if the current string contains the prefix at the start.
  4. If not, reduce the prefix by one character from the end and repeat the process.
  5. If the prefix is empty or the prefix is found at the start of each string, return the prefix.

Horizontal scanning

The horizontal scanning technique involves taking the first string as the initial prefix and then comparing it with the next string, shortening the prefix from the end with each mismatch. This process is continued for all strings in the array.

Time complexity

The time complexity of this solution is (O(S)), where (S) is the sum of all characters in all strings. The worst-case scenario occurs when all strings are identical.

Space complexity

The space complexity is (O(1)), as the space used by the algorithm is constant and does not grow with the size of the input array.

Test cases

Let's validate our function with a few test cases:

console.log(findLongestCommonPrefix(["flower","flow","flight"])); // "fl" console.log(findLongestCommonPrefix(["dog","racecar","car"])); // "" console.log(findLongestCommonPrefix(["interspecies","interstellar","interstate"])); // "inters"

Tips for optimization

  • Early stopping if a string is empty or if the prefix is reduced to zero length at any point.
  • Using a divide and conquer technique can improve performance on large datasets.
  • Implementing a trie data structure might yield better performance for a large number of strings with a complex set of common prefixes.

How to find the longest common prefix string amongst an array of strings in JavaScript

To find the longest common prefix among an array of strings in JavaScript, you can use the vertical scanning method. This technique compares characters from the top down at the same index of each string.

function longestCommonPrefix(strs) { if (strs.length === 0) return ''; for (let i = 0; i < strs[0].length; i++) { const char = strs[0][i]; for (let j = 1; j < strs.length; j++) { if (i === strs[j].length || strs[j][i] !== char) { return strs[0].substring(0, i); } } } return strs[0]; }

Vertical scanning explained

  1. Check if the array is empty; if so, return an empty string.
  2. Loop through each character of the first string.
  3. Compare the current character with the corresponding character of all other strings.
  4. If a mismatch is found or the end of a string is reached, return the common prefix up to the previous character.
  5. If the loop completes without a mismatch, the entire first string is the longest common prefix.

Test cases for vertical scanning

You can verify the correctness of the vertical scanning function with these test cases:

console.log(longestCommonPrefix(["alpine", "altitude", "algorithm"])); // "al" console.log(longestCommonPrefix(["blueberry", "blue", "bluetooth"])); // "blu" console.log(longestCommonPrefix(["zebra", "dog", "duck"])); // "" console.log(longestCommonPrefix(["prefix", "preform", "premise"])); // "pre"

When to use vertical scanning

Vertical scanning is particularly effective when:

  • The array has a very long string and the prefix is short because it stops checking once the shortest string's length is reached.
  • The number of strings is significantly greater than the length of the shortest string.

Invite only

The next generation of charts.

Coming soon.

The next generation of charts. Coming soon.

The next generation of charts. Coming soon.

Fast. Opinionated. Collaborative. Local-first. Keyboard centric. Crafted to the last pixel. We've got 50 slots for Alpha access.