[Leetcode] valid palindrome 验证回文
Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignoring cases.
For example,
"A man, a plan, a canal: Panama"is a palindrome.
"race a car"is not a palindrome.
Note: 
Have you consider that the string might be empty? This is a good question to ask during an interview.
For the purpose of this problem, we define empty string as valid palindrome.
题意:给定字符串,判断是否为回文。值得注意的是,只考虑字符和数字且不考虑字符大写小,其他情况忽略。
思路:判断是否为回文的情况,一般都是用两个指针,从字符串的两端开始向中间移动,若对应位置的字符不等则返回false。这里的区别在于,有空格和符号,而这些都是题中要求忽略的,所以,每当遇到空格和符号时,直接跳过就行,反应在代码上就是一个加加,一个减减;还有一点就是,这里是不考虑大小写的,所以需要写一个函数,遇到大写的时候转化成小写去比较(也可以小转大),其他不变。代码如下:
 class Solution {
 public:
     bool isPalindrome(string s)
     {
         int len=s.size();
         if(len==)  return true;
         int l=,r=len-;
         while(l<r)
         {
             if( !isAlpnum(s[l]))
                 l++;
             else if( !isAlpnum(s[r]))
                 r--;
             else if(toLower(s[l]) !=toLower(s[r]))
                 return false;
             else
             {
                 l++;
                 r--;
             }
         }
         return true;
     }
     bool isAlpnum(const char c)
     {
         if('A'<=c&&c<='Z')
             return true;
         else if('a'<=c&&c<='z')
             return true;
         else if(''<=c&&c<='')
             return true;
         return false;
     }
     char toLower(const char c)
     {
         if('A'<=c&&c<='Z')
             return c+;
         return c;
     }
 };
其中判断是否为字母和数字可以用函数isalnum,这样就可以少写一个函数,其余不变。参考了booirror的博客。
[Leetcode] valid palindrome 验证回文的更多相关文章
- [LeetCode] Valid Palindrome 验证回文字符串
		Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ... 
- [LeetCode] 125. Valid Palindrome 验证回文字符串
		Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ... 
- LeetCode  Valid Palindrome 有效回文(字符串)
		class Solution { public: bool isPalindrome(string s) { if(s=="") return true; ) return tru ... 
- [LintCode] Valid Palindrome 验证回文字符串
		Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ... 
- 125 Valid Palindrome 验证回文字符串
		给定一个字符串,确定它是否是回文,只考虑字母数字字符和忽略大小写.例如:"A man, a plan, a canal: Panama" 是回文字符串."race a c ... 
- [LeetCode] Prime Palindrome 质数回文数
		Find the smallest prime palindrome greater than or equal to N. Recall that a number is prime if it's ... 
- [leetcode]125. Valid Palindrome判断回文串
		Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ... 
- LeetCode 125. Valid Palindorme (验证回文字符串)
		Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ... 
- [LeetCode] 266. Palindrome Permutation 回文全排列
		Given a string, determine if a permutation of the string could form a palindrome. Example 1: Input: ... 
随机推荐
- Windows运行机理——API与SDK
			Windows运行机理这系列文章都是来至于<零基础学Qt4编程>——吴迪,个人觉得写得很好,所以搬运加以整理. 首先 API:Application Programmaing Interf ... 
- OSG-视口&LOD&Imposter
			本文转至http://www.cnblogs.com/shapherd/archive/2010/08/10/osg.html 作者写的比较好,再次收藏,希望更多的人可以看到这个文章 互联网是是一个相 ... 
- Qt-第一个QML程序-2-关键代码分析,TEXT,Image,Mouseare
			qml语言开始写的时候有点不习惯,后面用的多了感觉很好,很顺手,用于快速搭建项目界面,真的很好. 目前用到的还是比较简单的 隐藏标题栏,而依附任务栏 flags: Qt.Window | Qt.Fra ... 
- SpriteKit手机游戏摇杆JoyStick的使用 -- by iFIERO游戏开发教程
			### 工欲善其事,必先利其器 有时候学习如何应用第三方库是非常重要的,因为我们不用再自己重复造轮子,在这里,我们就把原先利用重力感应来操控飞机改为用游戏摇杆joystick来操控,具体的操作如下:` ... 
- fastCMS八大核心对象
			fastCMS内置system对象,该对象包含八大核心对象,应用于不同的操作场景,分别是: 1.system.string 对象(处理字符类操作) 2.system.number 对象(处理数字类操作 ... 
- 【springmvc+mybatis项目实战】杰信商贸-1.项目背景
			1.项目背景杰信项目物流行业的项目,杰信商贸是国际物流行业一家专门从事进出口玻璃器皿贸易的公司.公司总部位于十一个朝代的帝王之都西安,业务遍及欧美.随着公司不断发展壮大,旧的信息系统已无法满足公司的快 ... 
- JAVA基础学习之路(一)基本概念及运算符
			JAVA基础概念: PATH: path属于操作系统的属性,是系统用来搜寻可执行文件的路径 CALSSPATH: java程序解释类文件时加载文件的路径 注释: 单行注释 // 多行注释 /*... ... 
- 下拉网页div自动浮在顶部
			<!DOCTYPE html> <html> <head> <title></title> <style type="tex ... 
- Centos7下部署activeMQ消息队列服务
			#1.下载activeMQlinux包 http://activemq.apache.org/activemq-5100-release.html 下载linux的activeMQ包 #2.使用X ... 
- opencv-学习笔记(1)常用函数和方法。
			opencv-学习笔记(1)常用函数和方法. cv2.imread(filename,falg) filename是文件名字 flag是读入的方式 cv2.MREAD_UNCHANGED :不进行转化 ... 
