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,子序列
0
投稿

猜你喜欢

  • Android音乐播放器制作 加入控制台(三)

    2022-04-15 05:09:30
  • springboot应用访问zookeeper的流程

    2021-11-28 00:34:56
  • 详解JAVA动态代理

    2023-11-24 22:52:04
  • Java微信公众平台开发(12) 微信用户信息的获取

    2023-05-26 07:28:56
  • mybatis日志打印的两款IDEA插件推荐

    2022-01-12 07:55:52
  • 详解SpringBoot定制@ResponseBody注解返回的Json格式

    2023-07-26 13:47:02
  • C++中用指向数组的指针作函数参数

    2022-08-27 23:11:33
  • 浅析java 归并排序算法

    2022-01-20 09:59:50
  • 一篇超详细的Spring Boot整合Mybatis文章

    2022-01-27 10:02:58
  • 使用Java读取Word文件的简单例子分享

    2022-12-17 02:15:19
  • 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
  • 详解maven中profiles使用实现

    2022-11-13 23:14:24
  • 详解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
  • asp之家 软件编程 m.aspxhome.com