第柒届蓝桥杯 密码脱落

转发请注解出处:http://www.cnblogs.com/zhishoumuguinian/p/8377763.html

密码脱落

X星球的考古学家发现了一批西夏留下来的密码。这个密码是由A、B、C、D
三种植物的种子串成的队列。仔细分析发现,那一个密码串当初应有是前后对称的(也正是我们说的镜像串)。由于长期,在那之中不少种子脱落了,由此只怕会错过镜像的特点。你的职务是:给定3个现行反革命见到的密码串,总结一下从这儿的动静,它要起码脱落多少个种子,才大概会成为现在的规范。输入一行,表示今后看看的密码串(长度不当先壹仟)需要输出三个正整数,表示至少脱落了稍稍个种子。

例如,输入:
ABCBA
则程序应该出口:
0

再例如,输入:
ABDCDCBABC
则程序应该出口:
3

能源约定:
峰值内部存款和储蓄器消耗 < 256M
CPU消耗 < 1000ms

请严厉按供给输出,不要画蛇添足地打字与印刷类似:“请你输入…”
的盈余内容。全部代码放在同一个源文件中,调试通过后,拷贝提交该源码。

小心: main函数须求重返0
只顾: 只使用ANSI C/ANSI C++
标准,不要调用注重于编写翻译环境或操作系统的出色函数。
瞩目: 全部注重的函数必须通晓地在源文件中
#必威体育app官网,include <xxx>, 无法透过工程安装而省略常用头文件。

交付时,注意选用所梦想的编写翻译器类型。

思路:由难题知道左右子串是对称的,从左右子串中摇摆不定的拿去一些假名。要是拿去对称地点的字母,那么大家得以当作那对字母本来就不存在。若是拿去对称地点的1个假名,大家找左右子子串的公物部分,剩下的没有配对的,正是另二分之一被拿掉了的。所以剩多少个没配对,就必要补上多少个。因为不鲜明,字母是从哪里掉的,所以大家从头到尾求最大公共子串,然后在颇具子串里最大公共子串里最长的,必要补的正是最少的。不会求最长公共子串的,可以看《最长公共子串》。接下来粘上代码。

 1 #include <iostream>
 2 #include <algorithm>
 3 #include <math.h>
 4 #include <cstring>
 5 #include <vector>
 6 using namespace std;
 7 
 8 
 9 int Maxlen(char str1[], char str2[])//动规求最长公共子串
10 {
11     int maxlen[1005][1005];
12     int len1=strlen(str1), len2 = strlen(str2);
13     for(int i=0; i<len1; i++)
14     {
15         maxlen[0][i]=0;
16     }
17     for(int j=0; j<len2; j++)
18     {
19         maxlen[j][0] = 0;
20     }
21     for(int i=1; i<=len1; i++)
22     {
23         for(int j=1; j<=len2; j++)
24         {
25             if(str1[i-1]==str2[j-1])
26             maxlen[i][j]=maxlen[i-1][j-1]+1;
27             else
28             maxlen[i][j]=max(maxlen[i][j-1],maxlen[i-1][j]);
29         }
30     }
31     return maxlen[len1][len2];
32 }
33 
34 int main()
35 {
36     char str[1005];
37     cin>>str;
38     int len = strlen(str);//求出字符串长度
39     char str1[1005], str2[1005];//分别保存字符串的左右子串
40     vector<int>a;//用来保存返回来的最大公共子串长度
41     for(int i=0; i<len-1; i++)//从第一个开始,求左右子串
42     {
43         memcpy(str1, str, i+1);//复制左子串
44         str1[i+1]='\0';//别忘了给左子串加结束标志
45         reverse(str1,str1+i+1);//因为是对称,所以需要倒置
46         strcpy(str2, &str[i+1]);//复制右子串
47         a.push_back(Maxlen(str1,str2));
48     }
49     cout<<len-2*(*max_element(a.begin(),a.end()))-1;
50 }

即便本文对您有赞助,麻烦给个,多谢啊。。。。。。。。。

 

Post Author: admin

发表评论

电子邮件地址不会被公开。 必填项已用*标注