B - 辛普森一家的隐藏人才(KMP)

简介: B - 辛普森一家的隐藏人才(KMP)

题目:

荷马:玛吉,我刚想办法发现一些我们不知道的人才。

玛吉:是的,它是什么?

荷马:以我为例。我想知道我是否有政治才能,好吗?

玛吉:好的。

荷马:所以我采取一些政治家的名字,克林顿说,并试图找到最长前缀的长度

以克林顿的名字命名,这是我名字中的后缀。这就是我与克林顿这样的政治家有多接近

Marge:为什么选择最长的前缀是后缀???

荷马:嗯,我们的天赋深藏在我们自己里面,Marge。

玛吉:那你有多近?

荷马:0!

玛奇:我并不感到惊讶。

荷马:但是你知道,你必须拥有隐藏在你身边的一些真正的数学天赋。

玛奇:怎么样?

荷马:黎曼和马乔里3分!

Marge:Riemann到底是谁?

荷马:没关系。

编写一个程序,当给定字符串s1和s2时,找到s1的最后一个前缀,即s2的后缀。

input

输入包含两行。第一行包含s1,第二行包含s2。您可以假设所有字母都是小写的。

output

输出由一行组成,其中包含最长字符串,该字符串是s1的前缀和后缀s2,后跟该前缀的长度。如果最长的字符串是空字符串,则输出应为0。

s1和s2的长度最多为50000。

Sample Input

clinton
homer
riemann
marjorie

Sample Output

0
rie 3

解题思路:

这个题让我们求出最长的字符串,该长字符串是s1最后一个前缀,s2最后一个后缀,所以把s1,s2两个字符串连接成一个字符串,然后求出next[]数组,既字符串的长度就是next[ (s1和s2和起来的字符串长度)],注意:可能会出现类似 aaa,aaaaaa 这样的两个字符串,所以我们在输出时要先判断最大长度是否与本身输入字符串大,如果超过了本身字符串长度,就输出两个字符串中较短的那个。

程序代码:

#include<stdio.h>
#include<string.h>
char s[100000],s1[55000],s2[55000];
int n,m,k,next[100000],t,t1;
void get();
int main()
{
  int i,j,l;
  while(scanf("%s%s",s1,s2)!=EOF)
  {
    i=0;j=0;
    n=strlen(s1);
    m=strlen(s2);
    memset(next,0,sizeof(next));
    memset(s,0,sizeof(s));//注意字符串要清零h
    for(i=0;i<n;i++)
      s[i]=s1[i];
    for(j=0;j<m;j++)
      s[i++]=s2[j];
    k=strlen(s);
    get(); 
        
  }
  return 0;
}
void get()
{
  int i=1,j=0;
  int max;
  next[0]=-1;
  while(i<k)
  {
    if(j==-1||s[i]==s[j])
    {
      i++;
      j++;
      next[i]=j;
    }
    else
      j=next[j];
  }
  max=next[k];
  if(max>n) max=n;
  if(max>m) max=m;
  if(max==0)
    printf("%d\n",max);
  else
  {
    for(i=k-max;i<k;i++)
      printf("%c",s[i]);
    printf(" %d\n",max);
  }
  
}
相关文章
|
13天前
|
人工智能 算法
陶哲轩神预言!Transformer破解百年三体难题,凭数学直觉找到李雅普诺夫函数
在AI领域,语言模型处理复杂数学问题的能力一直受限。最近,由François Charton领导的团队利用Transformer模型成功解决了寻找李雅普诺夫函数这一百年难题,显著提升了动态系统的全局稳定性分析能力。该方法通过生成随机动态系统及其李雅普诺夫函数作为训练数据,使模型学会了从系统到函数的映射,不仅超越了传统算法和人类数学家的表现,还为解决其他数学难题开辟了新路径。
29 3
|
7月前
|
搜索推荐 程序员
IT圈的“鄙视链”:探讨技术领域的互相嫌弃文化
IT圈的“鄙视链”:探讨技术领域的互相嫌弃文化
|
决策智能
博弈论第十九集总结(“招商引资和战略投资”观后感)
博弈论第十九集总结(“招商引资和战略投资”观后感)
68 0
|
算法
敢不敢挑战这道《简单题》
这道题的题目和代码都很长,但是细节满满,值得一写
71 0
|
存储 算法 定位技术
“ 探索迷局:解密广度寻路算法 “(一)
“ 探索迷局:解密广度寻路算法 “
|
算法 定位技术
“ 探索迷局:解密广度寻路算法 “(二)
“ 探索迷局:解密广度寻路算法 “
|
算法 C++
蓝桥杯试题 算法训练 绘制地图 C/C++解法 AC(最近,WYF正准备参观他的点卡工厂。WYF集团的经理氰垃圾需要帮助WYF设计参“观”路线。现在,氰垃圾知道一下几件事情。。。。)
蓝桥杯试题 算法训练 绘制地图 C/C++解法 AC(最近,WYF正准备参观他的点卡工厂。WYF集团的经理氰垃圾需要帮助WYF设计参“观”路线。现在,氰垃圾知道一下几件事情。。。。)
119 0
|
算法
每天一道Leetcode题,拉开你们不是问题,卷中卷
每天一道Leetcode题,拉开你们不是问题,卷中卷
117 0
|
人工智能 程序员
格子披风背后,他们正用代码改变世界!
在阿里云 有一群 "别具匠心"的人儿 他们常常身披格子披风 手持键盘 惩恶除“bug“ ▽ “美国队长”亲手打造智能家居 木酱 在极限期限内 为视障人士 打造全智能家居 阿里云“维密天使” 清宵 即使一个人 也能带着代码 走遍世界的角落 车间里的代码高手 光盐 走进30多家工厂车间 为企.
2096 0