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;
    
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 高价求中通快递查询接口
  • ¥15 解决一个加好友限制问题 或者有好的方案
  • ¥15 关于#java#的问题,请各位专家解答!
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?