亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

POJ 2774 & URAL 1517(最長公共子串)

2019-11-14 09:10:12
字體:
來源:轉載
供稿:網友

題目鏈接:

URAL-1517 POJ-2774

題目大意:

就是給兩個字符串,求最長公共子串。

解題思路:

法一:常規動態規劃

好像是可以的(雖然我自己沒試(~ ̄▽ ̄)~) 因為常規的LCS是O(n^2)的,所以講LCS轉化成LIS,就可以在O(n log n)的時間內完成。 具體的講解看:LCS的nlogn法

法二:后綴數組

這個方法非常好,好像處理后綴數組可以使用O(n)或O(n log n) 不過后來查詢的時候可以做到O(n)

先將兩個字符串用 “#” 連接起來,比如 ‘abab’ + ‘nskfn’ —> ‘abab#nskfn’再來求他們的后綴數組,包括height的值,然后查詢每個height,記錄符合條件的最大值(條件:sa[i-1]和sa[i]在連接”#”的兩側) 然后就ok了。。。(^-^)V

下面是代碼:

#include<cstdio>#include<cstring>#include<algorithm>using namespace std;#define rep(i,x,y) for(int i = x;i <= y;i++)#define dep(i,x,y) for(int i = x;i >= y;i--)#define N 200010char str[N];int sa[N],r[N],h[N],s[N];int l1,l2,n;void read(){ scanf("%s",str); l1 = strlen(str); rep(i,0,l1-1) s[i] = str[i]; s[l1] = '$'; scanf("%s",str); l2 = strlen(str); rep(i,l1+1,l1+l2) s[i] = str[i - l1 - 1]; s[n = l1+l2+1] = 0;}int c[N],t[N],t1[N];void build(int n,int m){ int *x = t,*y = t1; rep(i,0,m-1) c[i] = 0; rep(i,0,n-1) c[x[i] = s[i]] ++; rep(i,1,m-1) c[i] += c[i-1]; for(int i = n-1;i >= 0;i--) sa[--c[x[i]]] = i; int p = 1; for(int k = 1;k < n;k <<= 1) { p = 0; rep(i,n-k,n-1) y[p++] = i; rep(i,0,n-1) if(sa[i] >= k) y[p++] = sa[i] - k; rep(i,0,m-1) c[i] = 0; rep(i,0,n-1) c[ x[y[i]] ]++; rep(i,1,m-1) c[i] += c[i-1]; for(int i = n-1;i >= 0;i--) sa[--c[ x[y[i]]]] = y[i]; swap(x,y);p = 1;x[sa[0]] = 0; rep(i,1,n-1) x[sa[i]] = y[sa[i]]==y[sa[i-1]] && y[sa[i]+k]==y[sa[i-1]+k] ? p-1 : p++; if(p >= n) break; m = p; }}void getheight(){ rep(i,1,n) r[sa[i]] = i; int k = 0; rep(i,0,n) { if(k) k--; int j = sa[r[i]-1]; while(s[i+k] == s[j+k]) k++; h[r[i]] = k; }}int main(){ read(); build(n+1,200); getheight(); int maxn = 0; rep(i,1,n) if(h[i] > maxn) { if(sa[i-1] < l1 && sa[i] > l1) maxn = h[i]; if(sa[i-1] > l1 && sa[i] < l1) maxn = h[i]; }
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久久久久久久久久久| 亚洲欧美综合精品久久成人| 久久影院在线观看| 国产mv免费观看入口亚洲| 韩国国内大量揄拍精品视频| 亚洲国产小视频| 成人午夜黄色影院| 欧美日韩在线视频一区| 亚洲日韩欧美视频一区| 97在线视频国产| 日韩精品极品视频| 另类天堂视频在线观看| 亚洲人成欧美中文字幕| www.色综合| 日韩精品中文字幕有码专区| 欧美精品第一页在线播放| 91日本在线视频| 欧美黑人狂野猛交老妇| 亚洲国产美女精品久久久久∴| 第一福利永久视频精品| 成人中文字幕+乱码+中文字幕| 日本不卡视频在线播放| 在线免费观看羞羞视频一区二区| 欧美成人性生活| 亚洲影院在线看| 91中文精品字幕在线视频| 丁香五六月婷婷久久激情| 欧美天堂在线观看| 91精品国产777在线观看| 欧美猛交ⅹxxx乱大交视频| 日韩福利伦理影院免费| 成人97在线观看视频| 国产拍精品一二三| 国产主播在线一区| 一二美女精品欧洲| 亚洲激情成人网| 欧美在线影院在线视频| 亚洲精品福利在线| 日韩av网站大全| 91精品成人久久| 国产精品www网站| 日韩大片在线观看视频| 亚洲精品美女免费| 日韩精品电影网| 亚洲嫩模很污视频| 国产午夜精品一区理论片飘花| 国产精品久久久av久久久| 亚洲成色777777在线观看影院| 成人黄色中文字幕| 午夜精品一区二区三区在线| 欧美一级高清免费播放| 欧美精品videosex极品1| 98精品国产自产在线观看| 日韩麻豆第一页| 久久久免费高清电视剧观看| 2018国产精品视频| 日韩国产中文字幕| 亚洲免费成人av电影| 色老头一区二区三区在线观看| 岛国视频午夜一区免费在线观看| 国产精品揄拍一区二区| 国产精品美女久久久久久免费| 欧美一区二区三区图| 成年人精品视频| 97色在线视频| 成人在线视频福利| 狠狠做深爱婷婷久久综合一区| 国产精品v片在线观看不卡| 国产福利成人在线| 深夜福利日韩在线看| 亚洲精品国产精品自产a区红杏吧| 精品一区二区三区四区在线| 欧美激情在线一区| 亚洲欧美国产高清va在线播| 777国产偷窥盗摄精品视频| 亚洲精品一区二三区不卡| 91网站在线免费观看| 亚洲精品久久久久国产| 91在线免费视频| 日韩av在线天堂网| 国产精品久久久久久亚洲调教| 国产精品成久久久久三级| 国产精品第三页| 91在线视频精品| 国内揄拍国内精品少妇国语| 精品高清一区二区三区| 欧美日韩在线免费| 亚洲欧美成人在线| 国产成人+综合亚洲+天堂| 日韩欧美国产免费播放| 欧美午夜电影在线| 国产亚洲在线播放| 美女福利精品视频| 亚洲永久免费观看| 国产精品观看在线亚洲人成网| 欧美日韩成人精品| 欧美另类高清videos| 欧美日韩成人精品| 日韩av在线最新| 美女撒尿一区二区三区| 亚洲第一精品自拍| 视频在线一区二区| 北条麻妃99精品青青久久| 欧美尺度大的性做爰视频| 欧美激情videoshd| 日韩视频免费在线| 疯狂欧美牲乱大交777| 欧美美女操人视频| 色天天综合狠狠色| 国产亚洲精品久久| 理论片在线不卡免费观看| 色婷婷av一区二区三区久久| 色综合久综合久久综合久鬼88| 日韩av中文字幕在线播放| 亚洲人成毛片在线播放| 久久精品亚洲94久久精品| 日韩欧美精品网址| 久久综合免费视频| 亚洲精品国产精品自产a区红杏吧| 疯狂蹂躏欧美一区二区精品| 亚洲国产成人精品电影| 777精品视频| 国产精品99久久久久久久久久久久| 一本色道久久综合狠狠躁篇怎么玩| 亚洲欧美日韩一区二区三区在线| 国产精品视频自在线| 亚洲视频专区在线| 欧美大片在线看免费观看| 精品成人69xx.xyz| 亚洲第一福利网站| 久久精品电影一区二区| 91免费观看网站| 久久777国产线看观看精品| 亚洲精品日产aⅴ| 亚洲色图偷窥自拍| 国产亚洲一区精品| 中文字幕精品av| 国产在线高清精品| 欧美另类69精品久久久久9999| 国产久一一精品| 日韩av网站电影| 91久久久久久久久久久| 国产亚洲精品美女久久久| 亚洲精品免费av| 欧美国产日韩xxxxx| 国产精品小说在线| 人妖精品videosex性欧美| 伊人久久精品视频| 欧美日韩成人网| 日韩精品在线第一页| 97在线免费观看| 91av免费观看91av精品在线| 久久99久久亚洲国产| 久久精品视频亚洲| 国产精品久久久久久超碰| 色香阁99久久精品久久久| 国产日韩在线观看av| 日韩在线观看精品| 欧美激情亚洲精品| 最近2019中文免费高清视频观看www99| 一区二区三区国产视频| 亚洲美女在线看| 日本欧美在线视频| 日韩综合中文字幕|