日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java实现最长连续子序列_最长公共子序列 ||

發布時間:2023/11/27 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java实现最长连续子序列_最长公共子序列 || 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問題:在 前一篇文章 最長公共子序列 | 的基礎上要求將所有的最長公共子序列打印出來,因為最長公共子序列可能不只一種。

難點:輸出一個最長公共子序列并不難,難點在于輸出所有的最長公共子序列,我們需要在動態規劃表上進行回溯——從C[a][b],即右下角的格子開始判斷:

1) 如果格子C[i][j]對應的X[i-1] == Y[j-1],則把這個字符放入 LCS 中,并跳入C[i-1][j-1]中繼續進行判斷;

2) 如果格子C[i][j]對應的X[i-1] ≠ Y[j-1],則比較C[i-1][j]和C[i][j-1]的值,跳入值較大的格子繼續進行判斷;

3)直到 i 或 j 小于等于零為止,倒序輸出 LCS 。如果出現C[i-1][j]等于C[i][j-1]的情況,說明最長公共子序列有多個,故兩邊都要進行回溯。

舉下面這個例子:x[6]={'B','D','C','A','B','A'}, y[7]={'A','B','C','B','D','A','B'}

通過LCSLength函數我們可以得到C表:如下表所示。

從最右下角我們可以知道最長公共子序列的長度為4,(從0開始編號)從最右下角的元素開始,C[6][7]行列元素對應A!=B,所以不加到 lcs_str(最長公共子序列串),然后考慮C[6][7](行列元素相等)和C[5][7](行列元素相等),而且C[6][7]大小等于C[5][7],所以分別從C[6][7]和C[5][7]開始同樣的操作,最后找到三條路徑,如上圖紅線標注,對應為BCAB、BCBA、BDAB。

代碼如下:

#include<iostream>
#include <fstream>
#include <cassert>
#include <string>
#include <sstream>
#include <set>
using namespace std;int c[100][100];
int d[100][100];
set<string> setOfLCS;string Reverse(string str)
{int low=0;int high=str.length()-1;while(low<high){char temp=str[low];str[low]=str[high];str[high]=temp;++low;--high;}return str;
}void LCSLength(int m,int n,char *x,char *y)
{int i,j;for(i=1;i<=m;i++)c[i][0]=0;for(i=1;i<=n;i++)c[0][i]=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;d[i][j]=1;}else if(c[i-1][j]>c[i][j-1]){c[i][j]=c[i-1][j];d[i][j]=2;}else{c[i][j]=c[i][j-1];d[i][j]=3;}}}
}void traceBack(int i,int j,char *x,char *y,string lcs_str)
{while(i>0&&j>0){if(x[i]==y[j]){lcs_str.push_back(x[i]);--i;--j;}else{if(c[i-1][j]>c[i][j-1])--i;else if(c[i-1][j]<c[i][j-1])--j;else{traceBack(i-1,j,x,y,lcs_str);traceBack(i,j-1,x,y,lcs_str);return;}}}setOfLCS.insert(Reverse(lcs_str));
}void LCS(int i,int j,char *x)
{if(i==0||j==0)return;if(d[i][j]==1){LCS(i-1,j-1,x);cout<<x[i];}else if(d[i][j]==2)LCS(i-1,j,x);elseLCS(i,j-1,x);
}void readTxt(string file)
{ifstream infile;infile.open(file.data());assert(infile.is_open());string s;getline(infile,s);int n=atoi(s.c_str());int num=1;while(n--){getline(infile,s);istringstream tmp(s);tmp>>s;int a=atoi(s.c_str());tmp>>s;int b=atoi(s.c_str());getline(infile,s);istringstream t1(s);char x[a];char t;for(int i=1;i<=a;i++){t1>>t;x[i]=t;}for(int i=1;i<=a;i++)cout<<x[i]<<" ";cout<<endl;getline(infile,s);istringstream t2(s);char y[b];for(int i=1;i<=b;i++){t2>>t;y[i]=t;}for(int i=1;i<=b;i++)cout<<y[i]<<" ";cout<<endl;cout<<"Case "<<num++<<endl;LCSLength(a,b,x,y);cout<<c[a][b]<<" ";cout<<"LCS(X,Y):";//LCS(a,b,x);cout<<endl;string str;setOfLCS.clear();traceBack(a,b,x,y,str);set<string>::iterator beg = setOfLCS.begin();for( ; beg!=setOfLCS.end(); ++beg)cout << *beg << endl;for(int i=0;i<=b;i++){for(int j=0;j<=a;j++){cout<<c[j][i]<<" ";}cout<<endl;}}infile.close();
}int main()
{readTxt("input.txt");return 0;
}

txt文件輸入如下:

運行結果如下:

總結

以上是生活随笔為你收集整理的java实现最长连续子序列_最长公共子序列 ||的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

歡迎分享!

轉載請說明來源于"生活随笔",并保留原作者的名字。

本文地址:java实现最长连续子序列_最长公共子序列 ||