【纵向扫描】最长公共前缀

求解代码

java 复制代码
public String longestCommonPrefix (String[] strs) {
        if(strs==null||strs.length==0){
            return "";
        }
        int rows = strs.length;
        int cols = strs[0].length();

        for(int i=0;i<cols;i++){
            char c = strs[0].charAt(i);
            for(int j=1;j<rows;j++){
                if(strs[j].length()==i||strs[j].charAt(i)!=c){
                    return strs[0].substring(0, i);
                }
            }
        }
        return strs[0];
    }

小贴士

纵向扫描的思路大概是:

以I【字符串数组】的第一个字符串的字符位置 为 "列",以i为列索引遍历每一列;

取第一个字符串的当前列字符c作为基准,以j为行索引

遍历【字符串数组】的其他所有字符串,对比同列的字符。

如果某个字符串长度等于当前列索引了,说明这个字符串已经没有更多字符了,

或者同列字符不一致

那就说明公共前缀到i-1列就结束了,

可直接返回strs[0].substring(0,i)

如果所有列都对比通过,说明第一个字符串就是最长公共前缀,直接返回strs[0]

相关推荐
翊谦1 天前
Java Agent开发 Milvus 向量数据库安装
java·数据库·milvus
晓晓hh1 天前
JavaSE学习——迭代器
java·开发语言·学习
Laurence1 天前
C++ 引入第三方库(一):直接引入源文件
开发语言·c++·第三方库·添加·添加库·添加包·源文件
查古穆1 天前
栈-有效的括号
java·数据结构·算法
kyriewen111 天前
你点的“刷新”是假刷新?前端路由的瞒天过海术
开发语言·前端·javascript·ecmascript·html5
Java面试题总结1 天前
Spring - Bean 生命周期
java·spring·rpc
硅基诗人1 天前
每日一道面试题 10:synchronized 与 ReentrantLock 的核心区别及生产环境如何选型?
java
014-code1 天前
String.intern() 到底干了什么
java·开发语言·面试
421!1 天前
GPIO工作原理以及核心
开发语言·单片机·嵌入式硬件·学习
摇滚侠1 天前
JAVA 项目教程《苍穹外卖-12》,微信小程序项目,前后端分离,从开发到部署
java·开发语言·vue.js·node.js