麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

【poj2185】Milking Grid

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

題意 在N*M字符矩陣中找出一個最小子矩陣,使其多次復制所得的矩陣包含原矩陣。N<=10000,M<=75 aba bab aba

ab ba

解法 先找出最大的K,使得原矩陣是若干個K*M的矩陣拼成一列后的子矩陣 把一行看做一個整體,對列做KMP 用應用1的方法確定最小行寬 再在K*M的矩陣中,把一列看做一個整體,用同樣的方法求最小行寬 O(N*M)

#include<iostream>#include<cstdio>#include<cstring>#include<string>#include<algorithm>using namespace std;const int N=10005;char w[N][80];int t[N],l[80],n,m,tmp;void calc_t(){ t[0]=-1; int j; for (int i=0;i<n;i++) { t[i+1]=i+1; for (int k=0;k<m;k++) { j=t[i]; while(w[i][k]!=w[j][k]&&j!=-1) j=t[j]; t[i+1]=min(++j,t[i+1]); } }}void calc_w(){ int j; l[0]=-1; for (int i=0;i<m;i++) { l[i+1]=i+1; for (int k=0;k<tmp;k++) { j=l[i]; while(w[k][i]!=w[k][j]&&j!=-1) j=l[j]; l[i+1]=min(++j,l[i+1]); } }}int main(){// freopen("std.in","r",stdin); cin>>n>>m; for (int i=0;i<n;i++) scanf("%s",w[i]); calc_t(); tmp=n-t[n]; calc_w(); int tmp1=m-l[m]; cout<<tmp*tmp1; return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 激情亚洲一区二区三区 | 欧美一级爱爱 | 国产亚洲精彩视频 | 精品亚洲视频在线 | 午夜视频在线观看91 | 一起草av在线 | 国产精品免费视频观看 | 亚洲一区二区三区在线看 | 国产三级a三级三级 | 在线免费日本 | 91午夜在线观看 | www.精品久久 | 国产欧美精品综合一区 | 欧美成人三级视频 | 国产精品www| 日韩黄色片免费看 | 九色成人在线 | 久久综合爱 | 日韩大片在线永久观看视频网站免费 | av免费在线网| 国产女厕一区二区三区在线视 | 草b视频在线观看 | 久久精热| 国产精品亚洲综合 | 欧美人的天堂一区二区三区 | 大学生一级毛片在线视频 | 久久影院免费观看 | 婷婷久久综合九色综合色多多蜜臀 | 免费看成年人网站 | 黄污在线看 | 色播一区| 电影av在线 | www.91在线观看 | h色网站免费观看 | 青青草在线免费观看 | 亚洲国产二区 | 一级做受大片免费视频 | 久久精品一区视频 | 久久国产精 | 久久免费视频一区二区三区 | 国产1区视频 |