网站首页 > 博客文章 正文
引言
字符串回文是C/C++面试中常见的问题之一,该内容主要考察面试者对于代码设计的鲁棒性、时间复杂度和空间复杂度的考虑,同时需要对代码的异常做和是判断,想要实现相关的代码不难,但是想要设计出鲁棒性较好的代码,需要花费一定的形式
示例需求描述
对于长度为n的一个字符串A(仅包含数字,大小写英文字母),请设计一个高效算法,计算其中最长回文子串的长度。
代码设计思路:通过回文字符串的特性,正反读取都相同,可以将字符串逆转后,求取最长公共子串,但可能会出现其他部分重置与另一部分相同,所以需要对比找到最长公共子串的索引与原索引相加是否为字符串长度-1,即 当A.at(right + 1) == A.at(left - 1)时,maxLen = right - left + 1;
测试用例:
示例1
输入:
"ababc"
返回值:
3
说明:
最长的回文子串为"aba"与"bab",长度都为3
示例2
输入:
"abbba"
返回值:
5
示例3
输入:
"b" 返回值:1
示例代码:
int getLongestPalindrome(string A, int n)
{
//边界条件判断
if (n < 2)
return A.length();
//maxLen表示最长回文串的长度
int maxLen = 0;
for (int i = 0; i < n; ) {
//如果剩余子串长度小于目前查找到的最长回文子串的长度,直接终止循环
// (因为即使他是回文子串,也不是最长的,所以直接终止循环,不再判断)
if (n - i <= maxLen / 2)
break;
int left = i;
int right = i;
while (right < n - 1 && A.at(right + 1) == A.at(right))
++right; //过滤掉重复的
//下次在判断的时候从重复的下一个字符开始判断
i = right + 1;
//然后往两边判断,找出回文子串的长度
while (right < n - 1 && left > 0 && A.at(right + 1) == A.at(left - 1)) {
++right;
--left;
}
//保留最长的
if (right - left + 1 > maxLen) {
maxLen = right - left + 1;
}
}
//截取回文子串
return maxLen;
}
};
结语
对于一个一个字符串的最大回文的计算,我们也可以使用的是中心位置法,遍历去头去尾的字符串,若字符串左边右边相等,则两个指针定位左边右边,同时向外扩展直到不相等,则回文长度是right_point - left_point - 1;若字符串左边或者右边的某一位与该字符串相等,则指针定位这两个相等的字符,并同时向外扩展直到不相等,方法相同。
猜你喜欢
- 2024-09-21 RS-485通讯:如何对固定长度报文方式来编程?这种专业好文不多见
- 2024-09-21 1750. 删除字符串两端相同字符后的最短长度
- 2024-09-21 C++趣味实用小实例:不使用变量实现求字符串长度的函数
- 2024-09-21 哪种网络密码安全性更高(哪些密码最安全)
- 2024-09-21 为提高安全性,LastPass现在要求用户的密码长度至少达到12字符
- 2024-09-21 excel函数利用FIND函数和MID函数组合提取文本中间指定长度的文本
- 2024-09-21 尚学堂知识整理:java字符串创建和长度
- 2024-09-21 MySQL中varchar类型字段最大长度是多少
- 2024-09-21 Java中的String,有没有长度限制?
- 2024-09-21 python笔记8:静静一起来学习-字符串相关方法
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)