★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:http://www.javashuo.com/article/p-amxtbgij-me.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
Write a function to find the longest common prefix string amongst an array of strings.git
If there is no common prefix, return an empty string ""
.github
Example 1:數組
Input: ["flower","flow","flight"] Output: "fl"
Example 2:微信
Input: ["dog","racecar","car"] Output: "" Explanation: There is no common prefix among the input strings.
Note:app
All given inputs are in lowercase letters a-z
.函數
編寫一個函數來查找字符串數組中的最長公共前綴。spa
若是不存在公共前綴,返回空字符串 ""
。code
示例 1:htm
輸入: ["flower","flow","flight"] 輸出: "fl"
示例 2:
輸入: ["dog","racecar","car"] 輸出: "" 解釋: 輸入不存在公共前綴。
說明:
全部輸入只包含小寫字母 a-z
。
16ms
1 class Solution { 2 func longestCommonPrefix(_ strs: [String]) -> String { 3 let minStr = try? strs.min(by: { $0.count < $1.count }) 4 guard var minS = minStr! else { 5 return "" 6 } 7 8 var endIndex = minS.endIndex 9 for str in strs { 10 if (str.hasPrefix(minS)) { 11 continue 12 } 13 while endIndex > minS.startIndex && !str.hasPrefix(minS) { 14 endIndex = minS.index(before: endIndex) 15 minS = String(minS[minS.startIndex..<endIndex]) 16 } 17 } 18 return minS 19 } 20 }
20ms
1 class Solution { 2 func longestCommonPrefix(_ strs: [String]) -> String { 3 4 if strs.count == 0 { 5 return "" 6 } 7 var prefix = strs[0] 8 for i in 0..<strs.count { 9 while strs[i].hasPrefix(prefix) == false { 10 prefix = prefix.substring(to: prefix.index(before: prefix.endIndex)) 11 if prefix.isEmpty { 12 return "" 13 } 14 } 15 } 16 return prefix 17 } 18 }
24ms
1 class Solution { 2 func longestCommonPrefix(_ strs: [String]) -> String { 3 guard strs.count > 0 else { return "" } 4 var shortestPrefix = strs.min{ $0.count < $1.count }! 5 print(shortestPrefix) 6 for s in strs { 7 while shortestPrefix.count > 0 , !s.hasPrefix(shortestPrefix) { 8 shortestPrefix.removeLast() 9 } 10 } 11 return shortestPrefix 12 } 13 }
28ms
1 class Solution { 2 func longestCommonPrefix(_ strs: [String]) -> String { 3 4 var res = "" 5 if strs.isEmpty { 6 7 return res 8 } 9 10 res = strs[0] 11 12 for i in 1..<strs.count { 13 14 var find = Array(strs[i]) 15 var current = Array(res) 16 res = "" 17 for i in 0..<find.count { 18 19 if i >= current.count { 20 break 21 } 22 23 if current[i] != find[i] { 24 25 break 26 } else { 27 28 res += String(current[i]) 29 } 30 } 31 32 } 33 34 return res 35 } 36 }
32ms
1 class Solution { 2 func longestCommonPrefix(_ strs: [String]) -> String { 3 guard let first = strs.first else { return "" } 4 5 var currentPrefix = "" 6 var bestPrefix = "" 7 8 for letter in first { 9 currentPrefix.append(letter) 10 11 for word in strs { 12 if !word.hasPrefix(currentPrefix) { 13 return bestPrefix 14 } 15 } 16 17 bestPrefix = currentPrefix 18 } 19 20 return bestPrefix 21 } 22 }