您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
本篇内容主要讲解“怎么用Java输出最长公共子串”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Java输出最长公共子串”吧!
1.简述:
给定两个字符串str1和str2,输出两个字符串的最长公共子串
题目保证str1和str2的最长公共子串存在且唯一。
数据范围: 要求: 空间复杂度 ,时间复杂度
输入:
"1AB2345CD","12345EF"
返回值:
"2345"
2.代码实现:
import java.util.*; public class Solution { public String LCS (String str1, String str2) { //dp[i][j]表示到str1第i个个到str2第j个为止的公共子串长度 int[][] dp = new int[str1.length() + 1][str2.length() + 1]; int max = 0; int pos = 0; for(int i = 1; i <= str1.length(); i++){ for(int j = 1; j <= str2.length(); j++){ //如果该两位相同 if(str1.charAt(i - 1) == str2.charAt(j - 1)) //则增加长度 dp[i][j] = dp[i - 1][j - 1] + 1; else //该位置为0 dp[i][j] = 0; //更新最大长度 if(dp[i][j] > max){ max = dp[i][j]; pos = i - 1; } } } return str1.substring(pos - max + 1, pos + 1); } }
到此,相信大家对“怎么用Java输出最长公共子串”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。