当前位置: 首页 > wzjs >正文

手机网站设计推荐网页版传奇排行

手机网站设计推荐,网页版传奇排行,wordpress 忘记数据库密码,wordpress文章对游客不显示0. 引言 ●子串(substring):原始字符串的一个连续子集; ●子序列(subsequence):原始字符串的一个子集。 1. 什么叫回文串? 如果一个字符串正着读和反着读是一样的,那它就是回文串。[1] 例如&…

0. 引言

●子串(substring):原始字符串的一个连续子集;
●子序列(subsequence):原始字符串的一个子集。

1. 什么叫回文串

如果一个字符串正着读和反着读是一样的,那它就是回文串。[1]

例如,字符串“apapa”无论从左到右还是从右到左读取,结果均为“apapa”。以下是回文串的核心特性:

  1. 对称性
    回文串的字符序列以中心为对称轴镜像对称。若字符串长度为奇数(如“radar”),对称轴是中间字符;若长度为偶数(如“abba”),对称轴位于中间两个字符之间。

假如回文的中心为 双数,例如 abba,对称轴是中间字符为 a bb a,

假为回文的中心为 单数,例如 abbabde, 对称轴是中间字符为a b b a b d e, 

 

 

  1. 字符位置对应
    对于长度为n的回文串,第i个字符与第n−i+1个字符必须相同(1≤i≤n)。例如,字符串“noon”中,第1个字符“n”与第4个字符“n”对应,第2个字符“o”与第3个字符“o”对应。

  2. 长度无关性
    回文串的长度可以是任意正整数,包括长度为1的字符(如“a”)或空字符串(通常也被视为回文)。

2. 代码实现

	string longestPalindrome(string s) {if (s.length() < 1){return "";}int start = 0, end = 0;for (int i = 0; i < s.length(); i++){int len1 = expandAroundCenter(s, i, i);//一个元素为中心int len2 = expandAroundCenter(s, i, i + 1);//两个元素为中心int len = max(len1, len2);if (len > end - start){start = i - (len - 1) / 2;end = i + len / 2;}}return s.substr(start, end - start + 1);}int expandAroundCenter(string s, int left, int right){int L = left, R = right;while (L >= 0 && R < s.length() && s[L] == s[R]){// 计算以left和right为中心的回文串长度L--;R++;}return R - L - 1;}

3. 逐行解析

string longestPalindrome(string s) 
{
  • 功能:主函数,输入字符串s,返回其中最长的回文子串。

if (s.length() < 1)
{return "";
}

  • 解释:如果字符串长度小于1(即为空),直接返回空字符串。

int start = 0, end = 0;

  • 功能startend用于记录当前找到的最长回文子串的起始和结束索引。

for (int i = 0; i < s.length(); i++)
{int len1 = expandAroundCenter(s, i, i); // 奇数长度回文中心int len2 = expandAroundCenter(s, i, i + 1); // 偶数长度回文中心int len = max(len1, len2);
  • 功能:对每个字符i,分别计算以它为中心的奇数长度回文(len1)和以它及其下一个字符为中心的偶数长度回文(len2),取两者中的较大值作为当前中心的最大回文长度。

if (len > end - start)
{start = i - (len - 1) / 2;end = i + len / 2;
}
  • start:计算当前回文的起始位置。对于长度为len,中心点在i处,起始位置为i - (len-1)/2
  • end:计算当前回文的结束位置,为i + len / 2

int expandAroundCenter(string s, int left, int right)
{int L = left, R = right;while (L >= 0 && R < s.length() && s[L] == s[R]){L--;R++;}return R - L - 1;
}
  • 功能:以leftright为左右中心,向两边扩展,计算最长回文的长度。
  • 过程
    • 初始时,L = leftR = right.
    • s[L] == s[R]且未超出字符串边界时,继续向外扩展。
    • 循环结束后,返回当前回文长度:R - L - 1.

参考文献

[1]最长回文子串 C / C++

http://www.dtcms.com/wzjs/613358.html

相关文章:

  • 盐城网站建设0515icp口碑最好的旅游网站
  • 网站首页设计特点有哪些中视频自媒体平台注册官网
  • 百度快速seowordpress的seo优化
  • 本校网站建设潍坊网站制作保定公司
  • 网站开发与维护是做什么工作制作小企业网站
  • 桂林网站制作找志合网络公司小网站备案
  • 建设能源官方网站七牛云加速WordPress
  • 建设厅网站总经济师是干什么的龙文区城乡建设局网站
  • 网站建设连接到百度计算机应用软件开发
  • 永久免费wap自助建站电商网站开题报告
  • 淘宝上做网站权重网站域名解析ip地址
  • 界面官方网站做食品外贸选哪个网站好
  • 多个域名指向同一个网站 备案wordpress同步qq微博
  • 做app网站建设学院网站设计流程
  • wordpress 备案信息网站如何做搜索引擎优化
  • 网站源码生成器电子商务网站开发的历程
  • 网站建设三网合一长春做网站大公司
  • 做网站维护的是什么人长沙制作公园仿竹围栏哪家便宜
  • 长沙市建设网站百度蜘蛛抓取新网站
  • 济南企业做网站国外做饮用来源的网站
  • 中国建设劳动学会是假网站吗网站制作公司昆明
  • 电商网站建设代理商企业微信邮箱怎么开通注册
  • 深圳网站搭建哪里找wordpress 静态页面显示文章
  • 济南企业做网站推广网站wordpress文字模板
  • 中国市场网湖北网站建设优化
  • 企业网站建设要伊春seo公司
  • 台州电子商务网站建设wordpress antivirus
  • 国外做的比较的ppt网站有哪些方面镇江嘉创网络科技有限公司
  • 企业站官方网站南通网站建设方案托管
  • 南通集团网站建设php的wordpress