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 ...
随机推荐
- Error 之 只能在执行Render() 的过程中调用 RegisterForEventValidation;
在实现"将GridView中的数据导出到Excel中"的时候出现了如下错误: 用户代码未处理 InvalidOperationException 只能在执行 Render() 的过 ...
- 深度学习-Caffe编译测试的小总结
1. 搭建的环境和代码:win7 64bit + vs2013+CUDA7.5 http://blog.csdn.net/thesby/article/details/50880802 2. 编译,制 ...
- Jlink烧写出错 : Unable to halt arm core
环境:TQ2440开发板,J-link 通过J-link向TQ2440开发板的Nor Flash烧写程序,执行烧写时出错:Unable to halt arm core-详情如下图所示: 解决办法: ...
- unity的 Social API
孙广东 2015.12.23 Social API Social API 是訪问的Unity 的point 社会功能.如:• 用户配置文件• 好友列表• 成就• 统计 / 排行榜 它提供了 ...
- Android——自定义多击事件
一:使用场景 Android本身内置了点击.双击事件,但是某些时候,我们可能需要多击事件. 例如:某个秘密入口,为了避免用户误操作点击.双击到了触发开关而进入到不该被用户看到的页面,我们可以为入口控件 ...
- 事件响应的优先级、stopProgapation禁止下层组件响应
cocos2d-js没有完整的鼠标事件处理,这点比js/flash的要差一些,不过凑合着也可以用了. 一般界面编程,可以用显示列表的Node作为监听器的优先级,在上方的会比下方的高优先级. 而coco ...
- python之模块pprint之常见用法
# -*- coding: cp936 -*- #python 27 #xiaodeng #python之模块pprint之常见用法 import pprint data = [(1,{'a':'A' ...
- Leveldb 使用说明文档
Leveldb 使用说明文档 原作者:Jeff Dean, Sanjay Ghemawat 翻译:乌合之众solym@sohu.com 英文原文地址https://rawgit.com/google/ ...
- logstash写日志elaticsearch不响应
在大量的解析日志并写入elasticsearch,在后端节点数据数量及磁盘性能等影响下,es不响应 问题描述: [--12T17::,][WARN ][logstash.outputs.elastic ...
- 【jquery】多日期选择插件easyui date
1.本次介绍一个好用的 多日期选择插件:EasyUI date,适用于:需要一次性选择多个日期,无需手动一个一个进行添加. 2.效果图: 3.下载地址:http://www.jeasyui.com/d ...