K闀垮害鐨勬ā寮忎覆錛孨闀垮害鐨勪富涓詫紝姹傚灝戜釜浣嶇疆鑳藉鍖歸厤銆?br />榪欓噷妯″紡涓蹭互鍙婁富涓查噷鐨勫煎潎涓簉ank錛屽嵆15567鍜?6678璁や負鏄尮閰嶇殑銆?br />
瑙f硶錛?br />瀵逛簬榪欑rank綾伙紝鍒ゆ柇鏄惁鐩哥瓑灝辨槸鍒ゆ柇鍦ㄦ鏁頒箣鍓嶅ぇ浜庤繖涓暟瀛楃殑鏁板瓧涓暟銆佺瓑浜庤繖涓暟瀛楃殑鏁板瓧涓暟浠ュ強灝忎簬榪欎釜鏁板瓧鐨勬暟瀛椾釜鏁版槸鍚﹀潎鐩哥瓑銆傛帴涓嬫潵鐨勮繃紼嬪氨綾諱技KMP鐨勫尮閰嶄簡銆?br />鍙﹀錛孠MP nxt鏁扮粍鏈川鏄渶闀垮悗緙=鏈闀垮墠緙錛?span style="color: red;">鍚屾椂瑕佹眰鍚庣紑涓嶈兘涓烘暣涓瓧絎︿覆銆傚ソ涔呬笉鍐橩MP錛岀珶鐒剁姱浜嗕釜緋婃秱鐨勪簨鎯咃紝nxt鏁扮粍閲岀畻鍑烘潵绔熺劧鏄?,2,3,4.銆傘傛棤璇?br />
浠g爜錛?br /> 1 Source Code
2 Problem: 3167 User: yzhw
3 Memory: 24496K Time: 813MS
4 Language: GCC Result: Accepted
5
6 Source Code
7
8 # include <stdio.h>
9 # include <string.h>
10 # define N 100005
11 # define M 30
12 int n,k,s;
13 int cal1[N][M],cal2[N][M],nxt[N],d1[N],d2[N];
14 int equal(int *e1,int *s1,int *e2,int *s2,int val1,int val2)
15 {
16 if(e1[val1-1]-s1[val1-1]==e2[val2-1]-s2[val2-1]&&
17 (e1[val1]-e1[val1-1])-(s1[val1]-s1[val1-1])==(e2[val2]-e2[val2-1])-(s2[val2]-s2[val2-1])&&
18 (e1[s]-e1[val1])-(s1[s]-s1[val1])==(e2[s]-e2[val2])-(s2[s]-s2[val2]))
19 return 1;
20 else return 0;
21 }
22 int main()
23 {
24 int i,t,j,p,total=0;
25 //freopen("cpattern.9.in","r",stdin);
26 //freopen("ans.txt","w",stdout);
27
28 scanf("%d%d%d",&n,&k,&s);
29 memset(cal1,0,sizeof(cal1));
30 memset(cal2,0,sizeof(cal2));
31 for(i=1;i<=n;i++)
32 {
33 scanf("%d",&t);
34 d2[i]=t;
35 //cal2[i][t]++;
36 for(j=1;j<=s;j++)
37 cal2[i][j]+=cal2[i-1][j];
38 for(j=t;j<=s;j++)
39 cal2[i][j]++;
40
41 }
42 for(i=1;i<=k;i++)
43 {
44 scanf("%d",&t);
45 d1[i]=t;
46 //cal1[i][t]++;
47 for(j=1;j<=s;j++)
48 cal1[i][j]+=cal1[i-1][j];
49 for(j=t;j<=s;j++)
50 cal1[i][j]++;
51 }
52 nxt[1]=0;
53 for(i=2;i<=k;i++)
54 {
55 p=nxt[i-1];
56 while(p&&!equal(cal1[p+1],cal1[0],cal1[i],cal1[i-p-1],d1[p+1],d1[i]))
57 p=nxt[p];
58 if(equal(cal1[p+1],cal1[0],cal1[i],cal1[i-p-1],d1[p+1],d1[i])) nxt[i]=p+1;
59 else nxt[i]=0;
60 }
61 p=0;
62 for(i=1;i<=n;i++)
63 {
64 while(p&&!equal(cal1[p+1],cal1[0],cal2[i],cal2[i-p-1],d1[p+1],d2[i])) p=nxt[p];
65 if(equal(cal1[p+1],cal1[0],cal2[i],cal2[i-p-1],d1[p+1],d2[i])) p++;
66 if(p==k)
67 {
68 total++;
69 p=nxt[p];
70 }
71 }
72 printf("%d\n",total);
73 p=0;
74 for(i=1;i<=n;i++)
75 {
76 while(p&&!equal(cal1[p+1],cal1[0],cal2[i],cal2[i-p-1],d1[p+1],d2[i])) p=nxt[p];
77 if(equal(cal1[p+1],cal1[0],cal2[i],cal2[i-p-1],d1[p+1],d2[i])) p++;
78 if(p==k)
79 {
80 printf("%d\n",i-k+1);
81 p=nxt[p];
82 }
83 }
84 return 0;
85 }
86
87

]]>