最长公共子串

1. 写一个算法查找两个字符串中公共最大的字符串。(要求:低时间复杂度)
如: abcdefabcd abefabghi 找出: efab

import java.util.Scanner;
import java.util.Stack;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        String str1 = in.next();
        String str2 = in.next();
        System.out.println(longestSubStr(str1, str2));
    }

    public static String longestSubStr(String str1, String str2) {
        String longestSubStr = "";
        String subStr = "";
        Boolean tag = false;
        for (int i = 0; i < str1.length(); ) {
            for (int j = 0; j < str2.length() && i < str1.length();) {
                if (str1.charAt(i) == str2.charAt(j)) {
                    subStr = subStr + str1.charAt(i);
                    i++;
                    j++;
                    tag = true;
                } else {
                    int k = 0;

                    if (tag) {
                        while (j < str2.length()) {
                            for (; k < subStr.length() && subStr.charAt(k) == str2.charAt(j);) {
                                k++;
                                j++;
                            }
                            if (k == subStr.length() && str1.charAt(i) == str2.charAt(j)) {
                                subStr = subStr + str2.charAt(j);
                                i++;
                                j++;
                            } else {
                                j++;
                            }
                        }
                    } else {
                        j++;
                    }
                }
            }
            if (subStr.length() > longestSubStr.length()) {
                longestSubStr = subStr;
            }
            if (!tag) {
                i++;
            }
            tag = false;
            subStr = "";
        }
        return longestSubStr;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值