HDU2594 Simpsons’ Hidden Talents 【KMP】
Simpsons’ Hidden Talents
Marge: Yeah, what is it?
Homer: Take me for example. I want to find out if I have a talent in politics, OK?
Marge: OK.
Homer: So I take some politician’s name, say Clinton, and try to find the length of the longest prefix
in Clinton’s name that is a suffix in my name. That’s how close I am to being a politician like Clinton
Marge: Why on earth choose the longest prefix that is a suffix???
Homer: Well, our talents are deeply hidden within ourselves, Marge.
Marge: So how close are you?
Homer: 0!
Marge: I’m not surprised.
Homer: But you know, you must have some real math talent hidden deep in you.
Marge: How come?
Homer: Riemann and Marjorie gives 3!!!
Marge: Who the heck is Riemann?
Homer: Never mind.
Write a program that, when given strings s1 and s2, finds the longest prefix of s1 that is a suffix of s2.
The lengths of s1 and s2 will be at most 50000.
clinton
homer
riemann
marjorie
0
rie 3
这题碰到了一些莫名其妙的问题,next数组本是记录模式串本身的匹配信息。我想着能不能用在两个不同的串上,然后就试验了一下,结果能想到的測试数据都能通过。可是就是WA。至今不知道错在哪里。
题意:给定两个串。求第二个串的后缀跟第一个串的前缀能匹配的最大长度并输出这个匹配串。
题解:在网上看到一种思路是将第一个串之后加入一个特殊字符,再把第二个串粘在第一个串后面,然后对这个新串求next数组。终于next[len]即为所求。
#include <stdio.h>
#include <string.h>
#define maxn 50002 char str1[maxn << 1], str2[maxn];
int ans, next[maxn << 1], len2; void getNext()
{
int i = 0, j = -1;
next[0] = -1;
while(str1[i]){
if(j == -1 || str1[i] == str1[j]){
++i; ++j;
next[i] = j;
}else j = next[j];
}
str1[ans = next[i]] = '\0';
} int main()
{
//freopen("stdin.txt", "r", stdin);
while(scanf("%s%s", str1, str2) == 2){
strcat(str1, " ");
strcat(str1, str2); getNext();
ans ? printf("%s %d\n", str1, ans) : printf("0\n");
}
}
放一个典型的错误代码。能想到的測试数据都通过了,可是提交就WA。不知道为什么。
#include <stdio.h>
#define maxn 50002 char str1[maxn], str2[maxn] = {' '};
int ans, next[maxn]; void getNext()
{
int i = 0, j = -1;
next[0] = -1;
while(str2[i]){
if(j == -1 || str2[i] == str1[j]){
++i; ++j;
next[i] = j;
}else j = next[j];
}
str1[ans = next[i]] = '\0';
} int main()
{
//freopen("stdin.txt", "r", stdin);
while(scanf("%s%s", str1, str2 + 1) == 2){
getNext();
ans ? printf("%s %d\n", str1, ans) : printf("0\n");
}
}
另外一个不知道错哪里的代码:
#include <stdio.h>
#define maxn 50002 char str1[maxn], str2[maxn] = {' ', ' '};
int ans, next[maxn]; void getNext()
{
int i = 0, j = -1;
next[0] = -1;
while(str2[i]){
if(j == -1 || str2[i] == str1[j]){
++i; ++j;
next[i] = j;
}else j = next[j];
}
str1[ans = next[i]] = '\0';
} int main()
{
//freopen("stdin.txt", "r", stdin);
while(scanf("%s%s", str1, str2 + 2) == 2){
getNext();
ans ? printf("%s %d\n", str1, ans) : printf("0\n");
}
}
HDU2594 Simpsons’ Hidden Talents 【KMP】的更多相关文章
- hdoj 2594 Simpsons’ Hidden Talents 【KMP】【求串的最长公共前缀后缀】
Simpsons' Hidden Talents Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java ...
- hdu 2594 Simpsons’ Hidden Talents 【KMP】
题目链接:http://acm.acmcoder.com/showproblem.php?pid=2594 题意:求最长的串 同一时候是s1的前缀又是s2的后缀.输出子串和长度. 思路:kmp 代码: ...
- hdu2594 Simpsons' Hidden Talents【next数组应用】
Simpsons’ Hidden Talents Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java ...
- HDU2594 Simpsons’ Hidden Talents —— KMP next数组
题目链接:https://vjudge.net/problem/HDU-2594 Simpsons’ Hidden Talents Time Limit: 2000/1000 MS (Java/Oth ...
- hdu2594 Simpsons’ Hidden Talents kmp
Simpsons’ Hidden Talents Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- HDU 2594 Simpsons’ Hidden Talents(KMP的Next数组应用)
Simpsons’ Hidden Talents Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java ...
- 【HDU 3746】Simpsons’ Hidden Talents(KMP求循环节)
求next数组,(一般有两种,求循环节用的见代码)求出循环节的长度. #include <cstdio> #define N 100005 int n,next[N]; char s[N] ...
- hdu2594 Simpsons’ Hidden Talents LCS--扩展KMP
Homer: Marge, I just figured out a way to discover some of the talents we weren’t aware we had.Marge ...
- kuangbin专题十六 KMP&&扩展KMP HDU2594 Simpsons’ Hidden Talents
Homer: Marge, I just figured out a way to discover some of the talents we weren’t aware we had. Marg ...
随机推荐
- Google想出了一个决定人员晋升的算法,然后就没有然后了......
Google 有点跑偏了,逗死我了~实践一下也好~ Prasad Setty 是 Google People Analytics 团队的副总裁.7 年前 Google 成立的这支团队的职责是收集和利用 ...
- 从 bootup.js 学习加载脚本等资源
本文内容 如何使用 示例 参考资料 本文的目的在于,通过 bootup.js 的源代码,认识如何从客户端加载服务器的文件,特别是 JavaScript 文件,注入到页面,并存储在本地缓存,以扩展对 J ...
- LintCode: Count and Say
C++ class Solution { public: /** * @param n the nth * @return the nth sequence */ string countAndSay ...
- linux测试工程介绍(Linux Test Project)
http://ltp.sourceforge.net/ Linux Test Project, 后台很硬,由SGI™ 发起, IBM维护,所以质量有保障. 里面介绍了很多工具,对于一般的基准测试应该是 ...
- setTimeout迭代替换setInterval
一.它们之间的区别 setTimeout - 仅执行一次 setInterval - 间隔执行 二.为什么推荐用setTimeout替换掉setIntelval? javascript是异 ...
- 使用JAVA的URL类处理url事例
import java.net.*; import java.io.*; public class ParseURL { public static void main(String[] args) ...
- 转:nginx基础概念(connection)
在nginx中connection就是对tcp连接的封装,其中包括连接的socket,读事件,写事件.利用nginx封装的connection,我们可以很方便的使用nginx来处理与连接相关的事情,比 ...
- Flash 矢量图和位图性能对比 导出为位图/缓存为位图 export as bitmap / cache as bitmap
大家都知道Flash处理矢量图比位图要慢,而具体的性能上对比也有不少的前人已经做过.http://bbs.9ria.com/forum.php?mod=viewthread&tid=2282 ...
- SCD Type2 in ODI
缓慢变化维(Slowly changing Dimensions)指的是维表中的维度字段值会随着时间或业务调整,而在后续的分析中,历史数据仍然要使用旧的维度值,新的数据会使用当前维度值.在数据仓库建设 ...
- 使用Cookie进行会话管理
javaweb学习总结(十一)——使用Cookie进行会话管理 一.会话的概念 会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. ...