Java最长公共子序列是什么
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章主要介绍"Java最长公共子序列是什么",在日常操作中,相信很多人在Java最长公共子序列是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Java最长公共子
千家信息网最后更新 2025年12月02日Java最长公共子序列是什么
这篇文章主要介绍"Java最长公共子序列是什么",在日常操作中,相信很多人在Java最长公共子序列是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Java最长公共子序列是什么"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
public class LongestCommonSubsequence3 { public static void main(String[] args) { LongestCommonSubsequence3 lcs = new LongestCommonSubsequence3(); System.out.println(lcs.compute("ABCBDAB","BDCABA")); } public static int compute(char[] str1, char[] str2) { int substringLength2 = str1.length; int substringLength3 = str2.length; // 构造二维数组记录子问题A[i]和B[j]的LCS的长度,默认初始化为0 int[][] chess = new int[substringLength2 + 1][substringLength3 + 1]; // 从从前到后,动态规划计算所有子问题。也可从前向后 for (int i = 1; i <= substringLength2; i++) { for (int j = 1; j <= substringLength3; j++) { if (str1[i - 1] == str2[j - 1]) chess[i][j] = chess[i - 1][j - 1] + 1;// 状态转移方程 else chess[i][j] = Math.max(chess[i - 1][j], chess[i][j - 1]);// 状态转移方程 } } System.out.println("substring1:" + new String(str1)); System.out.println("substring2:" + new String(str2)); System.out.print("LCS:"); int i = str1.length, j = str2.length; String temp = ""; while (i != 0 && j != 0) { if (str1[i - 1] == str2[j - 1]) { temp += str1[i - 1]; i--; j--; } else{ if (chess[i][j - 1] > chess[i - 1][j]) j--; else i--; } } for (int k = temp.length() - 1; k >= 0; k--) { System.out.print(temp.toCharArray()[k]); } System.out.println(); return chess[str1.length][str2.length]; } public int compute(String str1, String str2) { return compute(str1.toCharArray(), str2.toCharArray()); }}//================public class LongestCommonSubsequence2 { public static void main(String[] args) { LongestCommonSubsequence2 lcs = new LongestCommonSubsequence2(); System.out.println(lcs.compute("ABCBDAB","BDCABA")); } public static int compute(char[] str1, char[] str2) { int substringLength2 = str1.length; int substringLength3 = str2.length; // 构造二维数组记录子问题A[i]和B[j]的LCS的长度 int[][] opt = new int[substringLength2 + 1][substringLength3 + 1]; // 从后向前,动态规划计算所有子问题。也可从前到后。 for (int i = substringLength2 - 1; i >= 0; i--) { for (int j = substringLength3 - 1; j >= 0; j--) { if (str1[i] == str2[j]) opt[i][j] = opt[i + 1][j + 1] + 1;// 状态转移方程 else opt[i][j] = Math.max(opt[i + 1][j], opt[i][j + 1]);// 状态转移方程 } } System.out.println("substring1:" + new String(str1)); System.out.println("substring2:" + new String(str2)); System.out.print("LCS:"); int i = 0, j = 0; while (i < substringLength2 && j < substringLength3) { if (str1[i] == str2[j]) { System.out.print(str1[i]); i++; j++; } else if (opt[i + 1][j] >= opt[i][j + 1]) i++; else j++; } System.out.println(); return opt[0][0]; } public int compute(String str1, String str2) { return compute(str1.toCharArray(), str2.toCharArray()); }}//====================package com.lifeibigdata.algorithms.string;/** * Created by lifei on 16/5/25. */public class LongestCommonSubsequence { public static void main(String[] args) { char[] x = {' ','A','B','C','B','D','A','B'}; char[] y = {' ','B','D','C','A','B','A'}; LongestCommonSubsequence lcs = new LongestCommonSubsequence(); lcs.printLCS(lcs.lcsLength(x, y), x, x.length-1, y.length-1); } void printLCS(int[][] b,char[] x,int i,int j){ if(i == 0 || j == 0) return; if(b[i][j] == 1){ printLCS(b,x,i - 1,j - 1); System.out.print(x[i] + "\t"); }else if(b[i][j] == 2) printLCS(b,x,i - 1,j); else printLCS(b,x,i,j - 1); } int[][] lcsLength(char[] x,char[] y){ int m = x.length; int n = y.length; int i,j; int[][] c = new int[m][n]; int[][] b = new int[m][n]; for(i = 1;i < m;i++) c[i][0] = 0; for(j = 0;j < n;j++) c[0][j] = 0; for(i = 1;i < m;i++) for(j = 1;j < n;j++){ if(x[i] == y[j]){ c[i][j] = c[i - 1][j - 1] + 1; b[i][j] = 1; } else if(c[i - 1][j] >= c[i][j - 1]){ c[i][j] = c[i - 1][j]; b[i][j] = 2; }else{ c[i][j] = c[i][j - 1]; b[i][j] = 3; } } return b; }}/** * 滚动数组只求大小,可以降低空间复杂度,时间复杂度不变 * 求全部的lcs,使用深搜或广搜 * 求有几个lcs,即只求lcs数目,计算有多少分支,即2的多少次方 * * */
到此,关于"Java最长公共子序列是什么"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
问题
最长
序列
学习
数组
复杂
动态
复杂度
方程
更多
状态
长度
二维
帮助
规划
实用
接下来
分支
大小
数目
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
云南服务器硬盘代理
修改数据库字段性能
vox服务器
抖音软件开发难吗
浠水县公安网络安全队长是谁
喜马拉雅服务器更新
数据库中如何打印期刊
吐鲁番网络安全知识测试题
数据库怎么批量增加数据
文件服务器修改权限
计算机网络技术基础学习总结
谈网络安全
ftp服务器怎么实现全线管理
网络安全教育竞答
山西app软件开发定制
mysql数据库设计案例
app软件开发有哪些公司
网络安全规定关键信息
c 中数据库信息修改代码
武装突袭2局域网服务器怎么建
江苏开票安全服务器地址
河南武林网络技术公司
网络安全事态感知
为什么网络安全做不到位
怎样通过服务器上网
大同市国家网络安全周
网络安全协会会长什么人
软件开发校招题目
2021年青少年网络安全宣传
软件开发洪总