首页 > 其他 > 详细

【HDU 2087 剪花布条】

时间:2017-10-11 10:20:13      阅读:292      评论:0      收藏:0      [点我收藏+]

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 22610    Accepted Submission(s): 14136

Problem Description

一块花布条,里面有些图案,另有一块直接可用的小饰条,里面也有一些图案。对于给定的花布条和小饰条,计算一下能从花布条中尽可能剪出几块小饰条来呢?

Input

输入中含有一些数据,分别是成对出现的花布条和小饰条,其布条都是用可见ASCII字符表示的,可见的ASCII字符有多少个,布条的花纹也有多少种花样。花纹条和小饰条不会超过1000个字符长。如果遇见#字符,则不再进行工作。

Output

输出能从花纹布中剪出的最多小饰条个数,如果一块都没有,那就老老实实输出0,每个结果之间应换行。

Sample Input

abcde a3 aaaaaa aa #

Sample Output

0 3

Author

qianneng

Source

冬练三九之二

Recommend

lcy

 

题解:

     ①KMP算法,求不重复匹配数。

 

#include<stdio.h>
#include<cstring>
#define go(i,a,b) for(int i=a;i<=b;i++)
const int N=1000005;
int n,m,f[N],j,ans;
char T[N],P[N];
int main()
{
	while(ans=0,scanf("%s%s",T,P)==2)
	{
		m=strlen(P);
		n=strlen(T);
		f[0]=f[1]=0;
		
		go(i,1,m-1){j=f[i];while(j&&P[j]!=P[i])j=f[j];f[i+1]=P[j]==P[i]?j+1:0;}j=0;
		go(i,0,n-1){while(j&&P[j]!=T[i])j=f[j];m==(j+=T[i]==P[j])?ans++,j=0:1;}
		printf("%d\n",ans);
	}
	return 0;
}//Paul_Guderian

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

我打算在黄昏的时候出发,搭一辆车去远方,
今晚那儿有我友人的盛宴…… ——————汪峰《青春》

【HDU 2087 剪花布条】

原文:http://www.cnblogs.com/Damitu/p/7648795.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!