当前位置:首页 > 题解目录 > 正文内容

【题解】密码截获

亿万年的星光5年前 (2021-03-20)题解目录1781

【题目描述】

Catcher是MCA国的情报员,他工作时发现敌国会用一些对称的密码 进行通信,比如像这些ABBA,ABA,A,123321,但是他们有时会在开始或结束时加入一些无关的字符以防止别国破解。比如进行下列变化 ABBA->12ABBA,ABA->ABAKK,123321->51233214 。因为截获的串太长了,而且存在多种可能的情况 (abaaab可看作是aba,或baaab的加密形式),Cathcer的工作量实在是太大了,他只能向电脑高手求助,你能帮Catcher找出最长的 有效密码串吗?

【输入描述】

测试数据有若干行字符串,包括字母,数字,符号。(字母区分大小写)

【输出描述】

与输入相对应每一行输出一个整数,代表最长有效密码串的长度。

【样例输入】

ABBA
12ABBA
A
ABAKK
51233214
abaaab

【样例输出】

4
4
1
3
6
5

【题目分析】

  • 对称密码进行通信,就是这段代码中有回文,可以单独写个函数判断。

  • 只判断有没有回文还不行,题目中要求求“有效密码串”的最长长度。

  • 题目没有确定多少组,输入“不确定长度输入”类型。



【参考代码】

#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;

//判断回文函数 ,返回的是回文串的长度 
int HuiWen(char *s,int i,int j){
    int low=i,high=j;
    while(low!=high && s[low]==s[high]){
            low++;
            high--;
    }
    if(low>=high)
        return j-i+1;
    else
        return 0;
}
int main(){
    char str[10001]; //字符数组
//	cin>>str;
//	cout<<HuiWen(str,0,5); 
    while(cin>>str){ //不确定长度 
        int max=0; //初始化
        int k,len=strlen(str); //定义临时比较值和长度 
        for(int i=0;i<len;i++){
            for(int j=i+1;j<len;j++){  //双重for循环,暴力枚举 
                if(k=HuiWen(str,i,j)) //如果是回文 ,返回长度 
                    if(k>max)
		        max=k;  //找最大值的过程 
            }
        }
        if(len==1) //单独处理特殊情况,否则max会为0 
	    max=1; 
        cout<<max<<endl;
    }
    return 0;
}
/*
ABBA
12ABBA
A
ABAKK
51233214
abaaab
*/


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

【题解】加密(2019青岛市程序设计竞赛)

【问题描述】文件加密最简单的方法是把文件的原文中的每个字母用另一个字母来代替。假设原文中只包括26个英文字母(有大写和小写),没有其他符号,且长度不超过100,加密规则如下:原文abcdefghijk...

【题解】车厢调度

【题解】车厢调度

【题目描述】有一个火车站,铁路如图所示,每辆火车从A驶入,再从B方向驶出,同时它的车厢可以重新组合。假设从A方向驶来的火车有n节(n<=1000)。分别按照顺序编号为1,2,3,...n。假定在...

【题解】感应门

【题目描述】感应门会在有人经过的时候自动打开,冷却d 秒后自动关闭。如果有人在感应门打开的状态下通过,那么冷却时间会重置,重新冷却d秒后再关闭。在一段时间内,有 n个人陆续通过了感应门,他们...

【题解】寻找祖先

【题解】寻找祖先

【题目描述】给出充足的父子关系,请你编写程序找到某个人的最早的祖先。规定每个人的名字都没有空格,且没有任意两个人的名字相同。最多可能有1000组父子关系,总人数最多可能达到50000人,家谱中的记载不...

【题解】最低通行费

【题目描述】一个商人穿过一个N×N的正方形的网格,去参加一个非常重要的商务活动。他要从网格的左上角进,右下角出。每穿越中间1个小方格,都要花费1个单位时间。商人必须在(2N-1)个单位时间穿越出去。而...

数的拆分(1)

【题目描述】任何一个大于1的自然数n,总可以拆分成若干个小于n的自然数之和。例如:当n=7时7=1+1+1+1+1+1+1 7=1+1+1+1+1+2 7=1+1+1+1+3 7=1+1+1+2...