• lintcode :最长公共前缀


    题目

     最长公共前缀

    给k个字符串,求出他们的最长公共前缀(LCP)

    样例

    在 "ABCD" "ABEF" 和 "ACEF" 中,  LCP 为 "A"

    在 "ABCDEFG", "ABCEFG", "ABCEFA" 中, LCP 为 "ABC"

    解题

    思路:

    1.找到最短的字符串,求出长度shortest

    2.设最短公共前缀是shortest

    3.遍历所有字符串,比较长度是shortest的前缀是否相同,相同就是答案

    3.不相同shortest-=1 重复 2 、3 步

    Java

    public class Solution {
        /**
         * @param strs: A list of strings
         * @return: The longest common prefix
         */
        public String longestCommonPrefix(String[] strs) {
            // write your code here
            HashMap<Character,Integer> map= new HashMap<Character,Integer>();
            if(strs.length ==0)
                return "";
            int len = strs.length;
            int shortest = Integer.MAX_VALUE;
            for(int i=0;i<len;i++){
                int tmplen = strs[i].length();
                shortest = Math.min(shortest,tmplen);
            }
            int i =0;
            while(shortest>0){
                for( i=0;i<len-1;i++){
                    String str1 = strs[i].substring(0,shortest);
                    String str2 = strs[i+1].substring(0,shortest);
                    if( str1.equals(str2))
                        continue;
                    else
                        break;
                }
                if(i==len-1)
                    break;
                else
                    shortest--;
            }
            return strs[0].substring(0,shortest);
            
        }
    }
    Java Code

    既然可以倒着走,也可以正着走

    public class Solution {
        /**
         * @param strs: A list of strings
         * @return: The longest common prefix
         */
        public String longestCommonPrefix(String[] strs) {
            // write your code here
            if(strs.length ==0)
                return "";
            if(strs.length == 1)
                return strs[0];
            int len = strs.length;
            int shortest = 1;
            boolean flag = false;
            int i =0;
            while(!flag){
                for( i=0;i<len-1;i++){
                    if(strs[i].length() < shortest|| strs[i+1].length() < shortest){
                        flag = true;
                        break;
                    }
                    String str1 = strs[i].substring(0,shortest);
                    String str2 = strs[i+1].substring(0,shortest);
                    if( str1.equals(str2))
                        continue;
                    else
                        break;
                    }
                if(i==len-1)
                    shortest++;
                else{
                    flag= true;
                }
                    
            }
            return strs[0].substring(0,shortest-1);
            
        }
    }
    Java Code

    正着走就没有比较字符串,直接比较对应字符是否相等就好了

    public class Solution {
        /**
         * @param strs: A list of strings
         * @return: The longest common prefix
         */
        public String longestCommonPrefix(String[] strs) {
            // write your code here
            if(strs.length ==0)
                return "";
            if(strs.length == 1)
                return strs[0];
            int len = strs.length;
            int shortest = 0;
            boolean flag = false;
            int i =0;
            while(!flag){
                for( i=0;i<len-1;i++){
                    if(strs[i].length() <= shortest|| strs[i+1].length() <= shortest){
                        flag = true;
                        break;
                    }
                    char ch1 = strs[i].charAt(shortest);
                    char ch2 = strs[i+1].charAt(shortest);
                    if( ch1== ch2)
                        continue;
                    else
                        break;
                    }
                if(i==len-1)
                    shortest++;
                else{
                    flag= true;
                }
                    
            }
            return strs[0].substring(0,shortest);
            
        }
    }
    Java Code

    可能会发现三个返回结果为什么不一样?

    1.逆着找,取子串的方式是  substring(start,end)  取得是从start 到 end -1 位置内的字符,这里的shortest就相当于end 在最后比较结束的时候 shortest 是当前比较结束的位置,这个end位置内的前缀都一样

    所以返回的是substring(0,shortest) 取得字符是:0 到shortest -1的部分

    2.正着找,跳出循环的是 第一个不满足条件的shortest ,取子串的方式也是  substring(start,end) 需要进行shortest - 1

    3.比较字符,跳出循环的shortest是最长子串的后一个位置,可以直接用substring(0,shortest) 返回结果的

  • 相关阅读:
    可视化svg深入理解viewport、viewbox、preserveaspectradio
    async generator promise异步方案实际运用
    JavaScript中面相对象OOP
    css3:神秘的弹性盒子flexbox
    JavaScript:我总结的数组API
    CSS3:过渡大全
    CSS3奇特的渐变示例
    缓存:前端页面缓存、服务器缓存(依赖SQL)MVC3
    nohup
    video和audio
  • 原文地址:https://www.cnblogs.com/bbbblog/p/5131947.html
Copyright © 2020-2023  润新知