Java最长公共子序列是什么
发表于:2024-11-20 作者:千家信息网编辑
千家信息网最后更新 2024年11月20日,这篇文章主要介绍"Java最长公共子序列是什么",在日常操作中,相信很多人在Java最长公共子序列是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Java最长公共子
千家信息网最后更新 2024年11月20日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安全错误
数据库的锁怎样保障安全
山西网络安全警察
天津市服务器回收公司
服务器芯片供电
数据库建设包含什么
改变数据库排序规则
爸爸妈妈吉他谱软件开发
联益时代广州互联网科技有限公司
苏州智能化服务器哪个厂家质量好
三 网络安全培训
安卓版怪物猎人数据库
国贸软件开发培训
费县网络安全保卫大队
无法安全的连接到服务器
通州网络安全产业园智慧园区
本地服务器云桌面
茂名分布式服务器方案
数据库基础知识形考任务4
2015中国网络安全大会
网络安全控制怎么删掉
网购之维护网络安全
acs数据库怎么加入
聊城直销软件开发公司
全球网络技术大会2022年
部队里有软件开发的吗
软件开发机构宣传
网络安全会议什么时候结束
教师网络安全培训会议记录
联通和移动共用一个数据库吗
宝山区正规软件开发售后保障
mc面板如何看服务器里的人聊天