回文子串的个数_统计回文子串的个数

回文子串的个数_统计回文子串的个数1、题目描述本题要求统计一个字符串中包含多少个回文子串。首先我们来确定子串的概念:一个字符串的子串,就是指它本身的各个部分。如字符串“aba”的子串有“a”、“b”

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

1、题目描述

 

  1.1、题目

        本题要求统计一个字符串中包含多少个回文子串。首先我们来确定子串的概念:一个字符串的子串,就是指它本身的各个部分。如字符串“aba”的子串有“a”、“b”、“a”、“ab”、“ba”和“aba”。

       再来看回文,回文就是从左读到右和从右读到左都是一样的,长度为1的字符串也是回文。如“a”、“s”、”aa”、“aba”和“aabaa”等都是回文。

      本题在一个字符串中,单个字符也被认为是回文子串,相同的重复的子串也需要计算在内。本题要求判断一个字符串中的所有的子串是否是回文子串。如果用常规方法做,肯定会出现超时错误。这里采用由中心向外扩散的方法去判断一个子串是否是回文子串,如果最中心的子串不是回文,那么,立即终止,不必去判断向外围扩散的子串了,这就大大节约了时间。

      下面以“abaa”为例,讲解由中心向外扩散的方法,如下图所示。

回文子串的个数_统计回文子串的个数

(1)从左往右,钉住最后一个字符。

“abaa”串:先考查中心子串“ba”不是回文串,就可以判定“abaa”不是回文子串;

“baa”串:先考查中心子串“baa”不是回文,它是最外子串,不必向外扩散;

“aa”串:考查中心子串中“aa”是回文,它是最外子串,不必向外扩散。

(2)从右边倒数第二个字符往左,钉住第一个字符。

“aba”串:考查中心子串“aba”,是回文,它是最外子串,不必向外扩展;

“ab”串:考查子串“ab”,不是回文,它是最外子串,不必向外扩展;

这样下来,加上单个子串“a”,“b”,“a”,“a”4个,“abaa”中共包含6个回文子串。

  1.2、输入描述

输入数据中有多个测试案例。每个案例是一个非空且长度不超过5000的字符串。

处理到文件结尾。

   1.3、输出描述

在每行上打印该字符串中回文子串的个数。

  1.4、输入样例

aba

aa

  1.5、输出样例

4

3

2、C++实现

#include <iostream> 
using namespace std; 
int main(int argc, char* argv[]) { 
    char s[5000]; 
    int p, i, Half, Left, Right, Count; 
    while( cin>>s ) { 
        i = strlen(s); Count = 0; //从左到右钉住最后一个 
        for(p=0; p<=i-1; p++) { 
            Half = ((i-1)-p) / 2; //如果子串是奇数个 
            if( ((i-1)-p)%2 == 0 ) { 
                Left = p + Half - 1; 
                Right = p + Half + 1; 
            } 
            else { //如果子串是偶数个
                Left = p + Half; 
                Right = p + Half + 1; 
            } 
            while(Left >= p) { 
                if( s[Left] == s[Right]) { 
                    Count++; //发现了一个回文串 
                    Left--; 
                    Right++; 
                } else { //如果不相等,立即终止,由中心向外扩散不可能会有回文串 
                     break; 
                } 
            } 
        } //从右到左钉住第一个 
        for(p=i-2; p>=1; p--) { 
            Half = p / 2; //如果子串是奇数个 
            if(p%2 == 0) { 
                Left = Half - 1; 
                Right = Half + 1; 
            } else //如果子串是偶数个 { 
                Left = Half; 
                Right = Half + 1; 
            } 
            while( Left >= 0 ) { 
                if( s[Left] == s[Right] ) { 
                    Count++; //发现了一个回文串 
                    Left--; 
                    Right++; 
                } else { //如果不相等,立即终止,由中心向外扩散不可能会有回文串 
                    break; 
                } 
            } 
        } 
        printf("%d\n",Count + i); 
    } 
    return 0; 
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/181307.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • iPhone使用教程_iphone基础使用

    iPhone使用教程_iphone基础使用iPhone史上最全的使用教程iPhone的解锁、越狱、激活、固件等等是什么意思,有什么分别这几天看见好多新人问这几个词的含义及区别。我在这儿说说我的看法,不是官方解释,不懂的学习一下,懂的绕道,如有错误,敬请指正!第一次买来时或恢复官方固件后,iPhone会处于那种只能拨打紧急电话状态,不能使用其它功能,如果要使用其它功能,就必须进行一项操作,那就是“激活”。一般有锁版的只有使…

    2022年9月15日
    0
  • 子网掩码,反掩码与通配符之间的区别

    子网掩码,反掩码与通配符之间的区别1:子网掩码与反掩码的区别:反掩码就是通配符掩码通过标记0和1告诉设备应该匹配到哪位copy。由于跟子网掩码刚好相zd反,所以也叫反掩码例如掩码是255.255.255.0wildcard-mask就是0.0.0.255255.255.255.248反掩就是0.0.0.72:通配符掩码,ospf和Acl这儿用通配符掩码也不是每家的交换机都这么做,像cisco3550就是用的子网…

    2022年7月19日
    36
  • 简单的制作一个钓鱼网页游戏_简单网页制作代码

    简单的制作一个钓鱼网页游戏_简单网页制作代码网络钓鱼,一个价值很高的词语!如果你曾读过我的一篇文章《价值30亿美元的资料被窃取,网络钓鱼到底有多可怕!》就会知道,网络钓鱼到底有多”值钱”!如果对网络钓鱼这个词进行解释的话,简而言之,其就是一种黑客手段,或者是一种通过假装自己是受信任的实体来欺骗他人来获取凭据(账号、密码等信息)的方法。讲白话,都能听懂的就是去仿作一个和正规网站一样的登录页面,欺骗用户进行输入从而达到获取信息的目的!…

    2022年8月24日
    4
  • js刷新选项卡tabs

    js刷新选项卡tabs不忘初心,方得始终!

    2025年5月30日
    0
  • Mysql 实现多种逻辑删除方案

    Mysql 实现多种逻辑删除方案Mysql实现多种逻辑删除方案新增逻辑删除字段方式多deleted值deleted:0代表未删除,删除时把deleted赋值为时间戳UNIX_TIMESTAMP(NOW())采用备份表方式最近在做公司项目的时候,对于表的逻辑删除,和其他同事出现了不同意见,故查阅了一些blog,结合自己的实际情况,再次做了笔记,以备后查。在实际的项目开发中,对于某些业务数据,一般都不会采用物理删除的方式,…

    2022年5月5日
    184
  • 什么是字节码指令?[通俗易懂]

    什么是字节码指令?[通俗易懂]字节码指令简介: Java虚拟机的指令由一个字节长度的、代表着某种特定含义的数字(称为操作码,Opcode)以及跟随其后的零至多个代表此操作所需参数(称为操作数,Operands)而构成。由于Java虚拟机采用面向操作数栈而不是寄存器的架构,所以大多数的指令都不包含操作数,只有一个操作码。由于限制了Java虚拟机操作码的长度为一个字节,所以指令集的操作码总数不可能超过256条。字节码与数据…

    2022年10月7日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号