2238"回文字串"报告
题目描述:
回文串,就是从前往后和从后往前看都是一样的字符串。那么现在给你一个字符串,请你找出该字符串中,长度最大的一个回文子串。
输入描述:
有且仅有一个仅包含小写字母的字符串,保证其长度不超过5000
输出描述:
有且仅有一个正整数,表示最长回文子串的长度
输入样例:
abccbxyz
输出样例:
4
分析:
我的算法算是比较暴力的。这道题目中,需要输出最长的回文字串的长度,我的想法是从最长的长度开始寻找是否有回文字串符合这个长度,如果没有,则从次长的长度寻找是否有符合长度的回文字串。比如说,给定abccbxyz,它们分别对应a[0]-a[7],我们先从长度最长,也就是8开始查找,然后从a[0]开始寻找,如果a[0]和它后面的第(0 + 8 - 1)个数字相等,那么这个数字可能是回文字串,此时,从a[0 + 1]和a[8 - 2]开始比较,也就是字符串往中间收,如果有一组对应的字符不相等,那么就不是回文字串,接着就从a[1]为起点开始和a[1 + 8 - 1]开始比较,之后的过程和前面一样,当找到符合长度的回文字串是,就可以输出这个长度,然后结束。需要注意的是,每一个回文字串的起点的范围是:0-p - k,其中p是总字符串的长度,k是要寻找的长度,因为一旦起点大于p-k,那么终点为p-k+k等于p,而数组是这个下标代表的是'\0'。接下来,代码就很容易写出来了。
代码:
#include <stdio.h>
#include <string.h>
int main(void)
{
char a[5001];
int k,l,p,flag1,flag2,i,j,m,flag,flag3;
scanf ("%s",a);
p = strlen(a);//算出字符串的长度
for (k = p; k >= 1; k--)//k为需要寻找符合长度的回文字串的长度,从后往前找
{
flag3 = 0;//标记是否找到了符合长度的回文字串
for (i = 0; i <= p - k; i++)//起点的范围从0到p-k
{
if(a[i] == a[i + k - 1])//起点和终点相等,就需要开始比较这个字串
{
flag = 1;
if(k > 3)//当字串长度小于等于3时,如果起点相等,那么一定是回文串,则不需要进行下面的操作
{
for (flag1 = i + 1,flag2 = i + k - 2,m = i + k / 2 - 1; flag1 <= m; flag1++,flag2--)//从起点和终点往中间收
{
if(a[flag1] != a[flag2])//有一组对应的不相等,则不是回文串
{
flag = 0;
break;
}
}
}
else//k <= 3,当字串长度小于等于3时,如果起点相等,那么一定是回文串
{
flag3 = 1;
break;
}
if(flag)
{
flag3 = 1;//当没有对应的不相等,那么是回文串,进行标记表示找到了
break;
}
}
}
if(flag3)//找到了最长的回文字串,输出该长度,结束
{
printf ("%d\n",k);
break;
}
}
return 0;
}
总结:这种算法比较好理解,但也比较复杂,因为其时间复杂度是O(n^2),能A是因为数据还不算太大~
2238"回文字串"报告的更多相关文章
- 求字符串的最长回文字串 O(n)
昨天参加了某公司的校园招聘的笔试题,做得惨不忍睹,其中就有这么一道算法设计题:求一个字符串的最长回文字串.我在ACM校队选拔赛上遇到过这道题,当时用的后缀数组AC的,但是模板忘了没写出代码来. 回头我 ...
- hihocoder 第一周 最长回文字串
题目1 : 最长回文子串 时间限制:1000ms 单点时限:1000ms 内存限制:64MB 描述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相帮助,在编程 ...
- POJ 3974 最长回文字串(manacher算法)
题意:给出一个字符串,求出最长回文字串. 思路:一开始我直接上了后缀数组DC3的解法,然后MLE了.看了DISCUSS发现还有一种计算回文字串更加优越的算法,就是manacher算法.就去学习了一下, ...
- 最长回文字串——manacher算法
时间复杂度:O(n) 参考:https://segmentfault.com/a/1190000003914228 1.问题定义 最长回文子串问题:给定一个字符串,求它的最长回文子串长度. 如果一个字 ...
- hdu 4632区间dp 回文字串计数问题
Palindrome subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65535 K (Java/ ...
- P1435 回文字串
P1435 回文字串 题目背景 IOI2000第一题 题目描述 回文词是一种对称的字符串.任意给定一个字符串,通过插入若干字符,都可以变成回文词.此题的任务是,求出将给定字符串变成回文词所需要插入的最 ...
- 「Luogu P1435」回文字串 解题报告
题面 主要大衣大意: 给定一个字符串,求至少加入多少个字符才能使字符串变成回文字符串 下面就是我一本正经的胡说八道题解 思路: 很显然,这应该是一道典型的最长公共子序列的题目 因此,主要思想就是DP ...
- UVA 11584 划分回文字串
将其划分为尽可能少的回文串 dp[i] = min(dp[i],dp[j] + 1) 来表示j+1~i是回文串 #include <iostream> #include <cs ...
- 【POJ3974】最长回文字串
在这里采用的是哈希+二分的方法. 根据回文串的性质可知,可以将回文分成奇回文和偶回文分别进行处理. 对于奇回文来说,每次枚举的端点一定是重合的,因此只需计算出端点左右公共的长度是多少即可,因此二分的是 ...
随机推荐
- WannaflyUnion每日一题
---恢复内容开始--- 1. http://www.spoj.com/problems/KAOS/ 题意:给定n个字符串,统计字符串(s1, s2)的对数,使得s1的字典序比s2的字典序要大,s1反 ...
- 开关调色新世界BP2888电源解决方案
LED智能方案经过几年的拼杀,已经风靡照明界.但人们渐渐发现,对照明来说,一味追求花哨的功能并不被市场所认同,而其中开关调色,以其简单易操作的特点,已逐步融入广大消费者的生活习惯中.对吸顶灯,面板灯等 ...
- haproxy内存管理-free_list原理
haproxy的内存管理中,通过pool_head->free_list,存储空闲内存块,free_list是个二级指针,却把空闲内存块都串了起来,没有用next,pre之类的指针.怎么实现的? ...
- 从Thread,ThreadPool,Task, 到async await 的基本使用方法解读
记得很久以前的一个面试场景: 面试官:说说你对JavaScript闭包的理解吧? 我:嗯,平时都是前端工程师在写JS,我们一般只管写后端代码. 面试官:你是后端程序员啊,好吧,那问问你多线程编程的问题 ...
- Java之【线程通信】--标志位练习2
定义一个线程A,输出1 - 10之间的整数,定义一个线程B,逆序输出1 - 10之间的整数,要求线程A和线程B交替输出 方法一:非标志位方法 package Homework; //1 定义一个线程A ...
- 关于JS跨域问题的解决
这里不提供什么高深的代码了,只说明一个解决跨域问题的方法,个人觉得这个方法是最方便也是最有效的. 那就是一用不同源的JS,虽然JS不允许不同源的访问,但是可以引用不同源的JS,用这样的方法我们可以引用 ...
- windows embedded compact 2013 正版免费下载
不知道wince2013是不是真的免费了,不过可以试一下! 下载地址:http://www.microsoft.com/en-us/download/details.aspx?id=39268 你仍然 ...
- Spring学习(10)--- @Qualifier注解
按类型自动装配可能多个bean实例的情况,可以使用Spring的@Qualifier注解缩小范围(或指定唯一),也可以指定单独的构造器参数或方法参数 可用于注解集合类型变量 例子: package c ...
- Safari Private 模式下 localStorage 的问题
现如今好多浏览器都有「隐身模式」,Safari 管这叫「Private Browing」,国内各种牌子的套壳浏览器叫「无痕浏览」.私以为从命名上来说,倒是国内更中文一些. 这种模式下浏览网页踏雪无痕, ...
- shell脚本调用C语言之字符串切分之strtok函数
今天上午在写一个需求,要求的比较急,要求当天完成,我大致分析了一下,可以采用从shell脚本中插入一连串的日期,通过调用proc生成的可执行文件,将日期传入后台数据库,在数据库中进行计算.需要切分日期 ...