kmp 剪花布条 HDU - 2087
地址 https://vjudge.ppsucxtt.cn/problem/HDU-2087
一块花布条,里面有些图案,另有一块直接可用的小饰条,里面也有一些图案。对于给定的花布条和小饰条,计算一下能从花布条中尽可能剪出几块小饰条来呢?
Input
输入中含有一些数据,分别是成对出现的花布条和小饰条,其布条都是用可见ASCII字符表示的,可见的ASCII字符有多少个,
布条的花纹也有多少种花样。花纹条和小饰条不会超过1000个字符长。如果遇见#字符,则不再进行工作。
Output
输出能从花纹布中剪出的最多小饰条个数,如果一块都没有,那就老老实实输出0,每个结果之间应换行。
Sample Input
abcde a3
aaaaaa aa
#
Sample Output
0
3
解法
其实使用暴力查找也是可以过的
#include <iostream>
#include <vector>
#include <string>
using namespace std;
/*
abcde a3
aaaaaa aa
#
*/
int main()
{
while(1){
string a, b;
cin >> a;
if (a == "#") return 0;
cin >> b;
size_t pos = 0; int count = 0;
while (pos < a.size()) {
pos = a.find(b, pos);
if (pos == string::npos) { break; }
count++;
pos += b.size();
}
cout << count << endl;
}
return 0;
}
使用kmp模板解答,唯一需要注意的是,kmp是尽量匹配每个字符串,能够重叠,但是本题的剪花布条是进行匹配 但是不能重叠
需要做一点小改动
#include <iostream>
#include <vector>
#include <string>
using namespace std;
/*
abcde a3
aaaaaa aa
#
*/
int ne[2000];
char a[2000];
char b[2000];
int main()
{
while(1){
cin >> (a + 1);
if (a[1] == '#') break;
cin >> (b+1);
int m = strlen(a + 1);
int n = strlen(b + 1);
for (int i = 2, j = 0; i <= n; i++) {
while (j && b[i] != b[j + 1]) j = ne[j];
if (b[i] == b[j + 1]) j++;
ne[i] = j;
}
int count = 0;
for (int i = 1, j = 0; i <= m; i++) {
while (j && a[i] != b[j + 1]) j = ne[j];
if (a[i] == b[j + 1]) j++;
if (j == n) {
count++;
//j = ne[j];
j = 0;
}
}
cout << count << endl;
}
return 0;
}
作 者: itdef
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力


【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话
2020-10-04 LeetCode 5532. 奇偶树
2020-10-04 LeetCode 5518. 给定行和列的和求可行矩阵
2020-10-04 LeetCode 5516. 警告一小时内使用相同员工卡大于等于三次的人
2020-10-04 LeetCode 5531. 特殊数组的特征值 二分