LeetCode--初级算法--字符串类算法:验证回文字符串
时间:2019-02-21
本文章向大家介绍LeetCode--初级算法--字符串类算法:验证回文字符串,主要包括LeetCode--初级算法--字符串类算法:验证回文字符串使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
验证回文字符串
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例一
输入: “A man, a plan, a canal: Panama”
输出: true
示例二
输入: “race a car”
输出: false
算法分析:
- 首先将字符串的所有大写转换为小写。
- 编写一个函数,判断字符是否是字母和数字字符。是则返回true,否则返回flase.
- 从两端开始扫描字符串,判断两端的字符是否在范围内,此时分为4中情况:两端均在;前端在,后端不在;前端在,后端不在;两端均不在。然后分别判断。
代码:
class Solution {
public:
bool isPalindrome(string s) {
if(s.length() == 0)
return true;
transform(s.begin(),s.end(),s.begin(),::tolower);
cout<<s<<endl;
int iStart = 0;
int iEnd = s.length() - 1;
while(iStart < iEnd)
{
//在两端均在范围内
if(isChar(s[iStart]) && isChar(s[iEnd])){
//不相同直接退出
if(s[iStart] != s[iEnd]){
return false;
}
//相同寻找下一个
iStart++;
iEnd--;
//前端不在范围,后端在范围
}else if(!isChar(s[iStart]) && isChar(s[iEnd])){
iStart++;
//前端在范围,后端不在
}else if(isChar(s[iStart]) && !isChar(s[iEnd]))
{
iEnd--;
//两端均不在范围
}else{
iStart++;
iEnd--;
}
}
return true;
}
//判断字符范围
bool isChar(char s){
if((s >= 'a' && s <= 'z') || (s >= '0' && s <= '9')){
return true;
}
return false;
}
};
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 蓝牙---BLE GATT介绍
- Access数据库密码破解 C#
- 没啥用,更换注册表信息使webbrower选择适合的版本
- linux下分割和合并压缩包
- 编译.net .net Core程序 代码,仅做备份
- js删除数组对象中符合条件的数据
- .net core webapi jwt 更为清爽的认证 ,续期很简单(2)
- 手把手教你写一个windows服务 【基于.net】 附实用小工具{注册服务/开启服务/停止服务/删除服务}
- 一网打尽枚举操作 .net core
- Jenkins 发布.net core 程序,服务端无法下载nuget包的解决方法 error NU1102: 找不到版本为 (>= 3.1.6) 的包
- NET Core Kestrel部署HTTPS 一个服务器绑一个证书 一个服务器绑多个证书
- .net core webapi jwt 更为清爽的认证 ,续期很简单(1)
- 用flask来在线管理你的iptables
- Linux Shell命令速查表
- Windows10实现滑动锁屏