2B小猿 2014-07-29 12:56 采纳率: 0%
浏览 3034

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

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

  • 写回答

1条回答 默认 最新

  • 关注

    /**
    * 思路:"abdab" 拆分情况:1.ab abd abda abdab 2.bd bda bdab 3 da dab 4 ab 5 b
    *
    * @param str
    * @return
    */
    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;
    
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容