Java最长公共子序列示例源码
作者:进击的中国学渣 时间:2023-08-20 13:25:37
最长公共子序列(Longest Common Subsequence)定义:两个或多个已知数列的子序列集合中最长的就是最长公共子序列。其实说到最长公共子序列,还有一个要提到的是最长公共子串(Longest Common Substring),它指的是两个字符串中的最长公共子串,要求子串一定连续。关于最长公共子串的内容我们后续也会讲到,今天先来看下最长公共子序列的相关内容。
之前看过一个LCS算法的实现过程,觉得太过繁琐。自己写了一个比较简单的,此处仅仅介绍实现过程。
程序代码测试通过,需要的童鞋可以在这里拷贝一下,代码如下:
package com.wsy.dynamic;
import java.util.HashMap;
import java.util.Map;
public class ImpLCS {
public String getLCS(String str1, String str2, int n, int m){
validate(str1, str2);
char[] a = str1.toCharArray();
char[] b = str2.toCharArray();
int[][] c = new int[n+1][m+1];
//存放序列
Map<String,String> map = new HashMap<String,String>();
//初始化参数
for(int i = 0;i<=n;i++){
c[i][0] = 0;
map.put(i + "0", "");
}
for(int i = 0;i<=m;i++){
c[0][m] = 0;
map.put("0" + i, "");
}
for(int i = 1;i<=n;i++){
for(int j = 1;j<=m;j++){
if(a[i-1] == b[j-1]){
c[i][j] = c[i-1][j-1] + 1;
String tmp = map.get(changeNum(i-1,j-1));
map.put(changeNum(i,j), tmp + String.valueOf(a[i-1]));
}else{
if(c[i][j-1] > c[i-1][j]){
c[i][j] = c[i][j-1];
String tmp = map.get(changeNum(i,j-1));
map.put(changeNum(i,j), tmp);
}else{
c[i][j] = c[i-1][j];
String tmp = map.get(changeNum(i-1,j));
map.put(changeNum(i,j), tmp);
}
}
}
}
String key = changeNum(n,m);
return map.get(key);
}
/**
* 将数字拼接成字符串
* @param i
* @param j
* @return
*/
private String changeNum(int i, int j) {
StringBuilder sb = new StringBuilder(String.valueOf(i));
return sb.append(j).toString();
}
/**
* 验证参数
* @param str1
* @param str2
*/
private void validate(String str1, String str2) {
// 略
}
public static void main(String[] args) {
ImpLCS lcs = new ImpLCS();
String rs = lcs.getLCS("12345", "12334", 5, 4);
System.out.println("---:" + rs);
}
}
总结
以上是本文的全部内容网站的支持!
来源:http://blog.csdn.net/wengsy_5041/article/details/77720725
标签:java,子序列
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Android音乐播放器制作 加入控制台(三)
2022-04-15 05:09:30
![](https://img.aspxhome.com/file/2023/1/90151_0s.gif)
springboot应用访问zookeeper的流程
2021-11-28 00:34:56
![](https://img.aspxhome.com/file/2023/6/99856_0s.jpg)
详解JAVA动态代理
2023-11-24 22:52:04
Java微信公众平台开发(12) 微信用户信息的获取
2023-05-26 07:28:56
![](https://img.aspxhome.com/file/2023/4/93144_0s.jpg)
mybatis日志打印的两款IDEA插件推荐
2022-01-12 07:55:52
![](https://img.aspxhome.com/file/2023/4/74904_0s.jpg)
详解SpringBoot定制@ResponseBody注解返回的Json格式
2023-07-26 13:47:02
C++中用指向数组的指针作函数参数
2022-08-27 23:11:33
浅析java 归并排序算法
2022-01-20 09:59:50
![](https://img.aspxhome.com/file/2023/4/80944_0s.png)
一篇超详细的Spring Boot整合Mybatis文章
2022-01-27 10:02:58
![](https://img.aspxhome.com/file/2023/3/72313_0s.jpg)
使用Java读取Word文件的简单例子分享
2022-12-17 02:15:19
![](https://img.aspxhome.com/file/2023/8/87358_0s.png)
java抓包后对pcap文件解析示例
2022-11-23 20:21:53
如何把spring boot项目部署到tomcat容器中
2023-10-08 18:53:51
Java开发工具IntelliJ IDEA安装图解
2022-06-14 02:30:20
![](https://img.aspxhome.com/file/2023/4/69934_0s.png)
详解maven中profiles使用实现
2022-11-13 23:14:24
![](https://img.aspxhome.com/file/2023/2/64512_0s.jpg)
详解Vue响应式的部分实现
2022-12-21 23:25:53
Android CheckBox 的使用案例分析
2022-02-07 21:00:56
浅谈Java之Map 按值排序 (Map sort by value)
2021-06-20 01:23:10
Springboot整合Shiro的代码实例
2021-09-03 04:16:52
解析C#中委托的同步调用与异步调用(实例详解)
2022-12-24 19:06:47
Android使用TextView,设置onClick属性无效的解决方法
2022-06-27 11:32:39