回文子串[输出所有回文子串]

简介: 回文子串    总时间限制:1000ms  内存限制:65536kB描述    给定一个字符串,输出所有长度至少为2的回文子串。    回文子串即从左往右输出和从右往左输出结果是一样的字符串,    比如:abba,cccdeedccc都是回文字符串。
+关注继续查看

回文子串
    总时间限制:1000ms  内存限制:65536kB
描述
    给定一个字符串,输出所有长度至少为2的回文子串。
    回文子串即从左往右输出和从右往左输出结果是一样的字符串,
    比如:abba,cccdeedccc都是回文字符串。
输入
    一个字符串,由字母或数字组成。长度500以内。
输出
    输出所有的回文子串,每个子串一行。
    子串长度小的优先输出,若长度相等,则出现位置靠左的优先输出。
样例输入
    123321125775165561
样例输出
    33
    11
    77
    55
    2332
    2112
    5775
    6556
    123321
    165561

分析:

该题目输出格式要求比较特别:子串长度小的优先输出,若长度相等,则出现位置靠左的优先输出。

所以,这里分如下几个步骤来完成任务:

1、枚举子串的所有可能的长度 for(len=2;len<=n;len++)

2、当长度确定为len时,枚举所有长度为len的子串的开始点。

        maxBegin=n-len;
        for(begin=0;begin<=maxBegin;begin++)

3、当开始点和长度明确时,可以遍历该子串并判断其是否回文串。

            j=begin+len-1;
            for(i=begin;i<j;i++,j--)

详细代码如下:

 1 #include<stdio.h>
 2 #include<string.h>
 3 int main(int argc, char *argv[])
 4 {
 5     char a[505];
 6     int n,len,begin,maxBegin,i,j;
 7     freopen("29.in","r",stdin);
 8     scanf("%s",a);
 9     n=strlen(a);
10     for(len=2;len<=n;len++)//枚举子串的所有可能的长度
11     {
12         maxBegin=n-len;
13         for(begin=0;begin<=maxBegin;begin++)//枚举子串的开始点 
14         {
15             j=begin+len-1;
16             for(i=begin;i<j;i++,j--) //遍历当前子串(a[i]~a[begin+len-1]),判断是否回文串 
17             {
18                 if(a[i]!=a[j]) break;
19             }
20             if(i>=j)//是回文串
21             {
22                 j=begin+len-1;
23                 for(i=begin;i<=j;i++) printf("%c",a[i]);
24                 printf("\n");
25             }
26         }
27     } 
28     return 0;
29 }

 

相关文章
|
1月前
字符串的全排列
字符串的全排列
17 0
|
4月前
|
算法 前端开发 JavaScript
[LeetCode] 无重复字符的最长子串 & 最长回文子串
博主最近在看新的工作机会,也是在找一些leetcode上比较高频的算法复习一下,这里分享两道算法题的解题。
37 2
[LeetCode] 无重复字符的最长子串 & 最长回文子串
|
7月前
LeetCode——821. 字符的最短距离
LeetCode——821. 字符的最短距离
33 0
|
8月前
|
Shell Python
LeetCode 821. 字符的最短距离
给你一个字符串 s 和一个字符 c ,且 c 是 s 中出现过的字符。
63 0
|
10月前
回文串
题目描述: 回文串是从左到右或者从右到左读起来都一样的字符串,试编程判别一个字符串是否为回文串。
91 0
|
10月前
|
算法
LeetCode算法:求出字符串的最大回文子串 及 长度【只利用字符串反转就可】
LeetCode算法:求出字符串的最大回文子串 及 长度【只利用字符串反转就可】
41 0
|
10月前
|
存储
LeetCode(1-两数之和&&2-两数相加&&3-无重复字符的最长子串)
LeetCode(1-两数之和&&2-两数相加&&3-无重复字符的最长子串)
LeetCode(1-两数之和&&2-两数相加&&3-无重复字符的最长子串)
AcWing 761. 字符串中的数字个数
AcWing 761. 字符串中的数字个数
36 0
AcWing 761. 字符串中的数字个数
|
存储 算法 C#
C#算法题系列(二)各位相加、 整数反转、回文数、罗马数字转整数
C#算法题系列(二)各位相加、 整数反转、回文数、罗马数字转整数
107 0
|
算法 索引
[译]最长回文字符串
原文链接: Longest Palindromic Substring 找到最长回文字符串是一个经典的编码面试问题,本文总结了针对这个问题的3中不同的解决方案。
668 0