题目大意:
最长公共前缀
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""
。
示例 1:
输入: ["flower","flow","flight"] 输出: "fl"
示例 2:
输入: ["dog","racecar","car"] 输出: "" 解释: 输入不存在公共前缀。
说明:
所有输入只包含小写字母 a-z
。
如果想查看本题目是哪家公司的面试题,请参考以下免费链接: https://leetcode.jp/problemdetail.php?id=14
解题思路分析:
本体使用暴力解即可。从第一位开始比较每个字符串上该位置的字符,如果存在不同或者当前位超过某个字符串长度范围,结束循环。返回之前的子串即可。
实现代码:
public String longestCommonPrefix(String[] strs) { if(strs.length==0) return ""; StringBuilder sb=new StringBuilder(); int index=0; while(true){ if(index==strs[0].length()) return sb.toString(); char c = strs[0].charAt(index); for(int i=1;i<strs.length;i++){ if(index==strs[i].length()) return sb.toString(); if(strs[i].charAt(index)!=c) return sb.toString(); } sb.append(c); index++; } }
本题解法执行时间为0ms。
Runtime: 0 ms, faster than 100.00% of Java online submissions for Longest Common Prefix.
Memory Usage: 37.4 MB, less than 95.32% of Java online submissions for Longest Common Prefix.
本网站文章均为原创内容,并可随意转载,但请标明本文链接如有任何疑问可在文章底部留言。为了防止恶意评论,本博客现已开启留言审核功能。但是博主会在后台第一时间看到您的留言,并会在第一时间对您的留言进行回复!欢迎交流!
本文链接: http://leetcode.jp/leetcode-14-longest-common-prefix-解题思路分析/