首页 > 其他 > 详细

LeetCode 7最长公共前缀

时间:2018-08-08 21:52:13      阅读:180      评论:0      收藏:0      [点我收藏+]

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""

示例 1:

输入: ["flower","flow","flight"]
输出: "fl"

示例 2:

输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。

说明:

所有输入只包含小写字母 a-z 。

 

思路:

要求最长的公共前缀,就是求字符串数组所有字符串前面相同的部分。

创建一个新函数来比较两个字符串前面相同的长度。

通过比较字符串0和剩余字符串的公共前缀,选出最小的长度即为最长公共前缀。

class Solution {
    public String longestCommonPrefix(String[] strs) {
        if (strs.length==0)return "";
        if (strs.length==1)return strs[0];
        int sameCharNum=0;
        Set<Integer> set=new HashSet<>();
        for (int i = 1; i < strs.length; i++) {
            sameCharNum = longestNum(strs[0], strs[i]);
            set.add(sameCharNum);
        }
        int minNum=Integer.MAX_VALUE;
        for (int i:set){
            if(minNum>i){
                minNum=i;
            }
        }
        return strs[0].substring(0,minNum);
    }

    public int longestNum(String s1,String s2){
        int sameCharNum=0;
        for (int i = 0; i<s1.length()&&i<s2.length(); i++) {
            if (s1.charAt(i)==s2.charAt(i)) {
                sameCharNum++;
            }else
                return sameCharNum;
        }
        return sameCharNum;
    }
}

 

LeetCode 7最长公共前缀

原文:https://www.cnblogs.com/TeFuir/p/9445840.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!