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

【题解】密码截获

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

【题目描述】

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
*/


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

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

分享给朋友:

相关文章

【题解】会场安排

【题目描述】学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办。小刘的工作就是安排学校小礼堂的活动,每个时间最多安排一个活动。现在小刘有一些活动计划的时间表...

【题解】跳格子

【题目描述】地面上有一排长度为n的格子1-n,每个格子上都有一个数xi,开始时你在位置0,每次你可以向前跳1-2格,然后取走格子上的数,直到跳到位置n+1。取走的数的和就是你的得分,现在你想知道你可能...

字符串移位包含问题

【题目描述】对于一个字符串来说,定义一次循环移位操作为:将字符串的第一个字符移动到末尾形成新的字符串。给定两个字符串 s_1s1 和 s_2s2,要求判定其中一个字符串是...

【题解】大数取模

【题目描述】求m%n。【输入描述】两个数,m和n。【输出描述】m模n的值。【样例输入】3【样例输出】2【数据范围】对于30%的数据, 1<m<10^18对于70%的数据, m>10^...

【题解】约瑟夫问题2

【题解】约瑟夫问题2

【题目描述】M个人围成一圈,每分钟相邻的两个人可以交换位置(只能有一对交换)。求使M个人的顺序颠倒(即每个人左边相邻的人换到右边,右边相邻的人换到左边)所需的最少时间(分钟数)。【输入描述】 ...

【题解】最大平方因子

【题目描述】给定一个整数 n,请找出 n 的最大平方因子。所谓平方因子,就是一个 n 的因子,且是一个完全平方数。最大平方因子就是 n&nb...