开发者社区> 问答> 正文

求字符串中相同最长的字串

用java程序写 题目:输入一行字母组成的字符串,找出其中出现的相同且
长度最长的字符串,输出它及其首字符的位置。
如yyabrdabjcabreg,则输出为abr,3。异常情况输出-1

展开
收起
蛮大人123 2016-02-20 14:42:41 2645 0
2 条回答
写回答
取消 提交回答
  • LCS,最长公共子序列?
    2019-07-17 18:45:19
    赞同 展开评论 打赏
  • 我说我不帅他们就打我,还说我虚伪
    /**
     * 思路:"abdab" 拆分情况:1.ab abd abda abdab 2.bd bda bdab 3 da dab 4 ab 5 b
     * 
     */
     public static String find(String str) {
     String reg;// 最大字符串
    String left;// 剩余字符串
    int k = 0;// 计数器
    int len = 0;// 最大字符串的长度
    String result = null;// 最终结果
    for (int i = 0; i < str.length(); i++) {
            for (int j = 0; j < str.length() - i; j++) {
                if (k < (j + 1)) {
                    // 将字符串拆分成若干个子串
                    reg = new String(str.substring(k, j + 1));
                    left = new String(str.substring(j + 1));
    
                    if (left.indexOf(reg) != -1 && reg.length() != 1) {
    
                        if (reg.length() > len) {
                            result = reg;
                            len = reg.length();
                        }
                    }
                }
            }
            k++;
        }
        return result;
    
    }
    2019-07-17 18:45:19
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载