[leetcode]_Valid Palindrome
题目:判断一个数字字符串是否是回文串。空串认为是回文串。
思路:双指针问题,重点在于此题的很多陷进:例如,s = " " ,return true。 s = ".," , return true。
代码:修改了很多遍,终于AC , 要点在于只有当头尾两个指针都指向数字或者字母时,此时才有比较操作,否则都认为是相等的。
 public boolean isPalindrome(String s) {
         int i = 0 , j = s.length() - 1;
         char left = 0 , right = 0 ;
         while( i <= j ){ // 控制循环结束,所有元素都已经遍历过了。
             left = s.charAt(i);
             if(!ifLegal(left)){
                 i++;
                 continue;
             }  
             right = s.charAt(j);
             if(!ifLegal(right)) {
                 j--;
                 continue;
             }
             //只有当left 和 right 同时指向数字、字母时,才进行比较;其它情况都认为是相等的。
             if((left != right && Math.abs(left - right) != ('a' - 'A'))) return false;
             i++;
             j--;
         }
         return true;
     }
     public boolean ifLegal(char ch){
         if(ch >= 'a' && ch <= 'z') return true;
         if(ch >= 'A' && ch <= 'Z') return true;
         if(ch >= '0' && ch <= '9') return true;
         return false;
     }
[leetcode]_Valid Palindrome的更多相关文章
- [LeetCode] 131. Palindrome Partitioning 回文分割
		Given a string s, partition s such that every substring of the partition is a palindrome. Return all ... 
- [LeetCode] 267. Palindrome Permutation II 回文全排列 II
		Given a string s, return all the palindromic permutations (without duplicates) of it. Return an empt ... 
- [LeetCode] Longest Palindrome 最长回文串
		Given a string which consists of lowercase or uppercase letters, find the length of the longest pali ... 
- [LeetCode] Shortest Palindrome 最短回文串
		Given a string S, you are allowed to convert it to a palindrome by adding characters in front of it. ... 
- [LeetCode] Valid Palindrome 验证回文字符串
		Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ... 
- LeetCode Longest Palindrome
		原题链接在这里:https://leetcode.com/problems/longest-palindrome/ 题目: Given a string which consists of lower ... 
- LeetCode Shortest Palindrome
		原题链接在这里:https://leetcode.com/problems/shortest-palindrome/ 题目: Given a string S, you are allowed to ... 
- leetcode@ [336] Palindrome Pairs (HashMap)
		https://leetcode.com/problems/palindrome-pairs/ Given a list of unique words. Find all pairs of dist ... 
- LeetCode——Valid Palindrome
		Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignori ... 
随机推荐
- 编写webpy程序,iep 报错,ulipad 运行正确
			在web.py编程中,使用模板文件时,iep下会报错.ulipad不会报错. 用python 运行不报错. 在寻找答案.初步估计是iep的python运行环境有问题. 如图: 
- Codeforces 452D [模拟][贪心]
			题意: 给你k件衣服处理,告诉你洗衣机烘干机折叠机的数量,和它们处理一件衣服的时间,要求一件衣服在洗完之后必须立刻烘干,烘干之后必须立刻折叠,问所需的最小时间. 思路: 1.按照时间模拟 2.若洗完的 ... 
- (easy)LeetCode  205.Isomorphic Strings (*)
			Given two strings s and t, determine if they are isomorphic. Two strings are isomorphic if the chara ... 
- Android系统下的动态Dex加载
			1 问题在Android系统中,一个App的所有代码都在一个Dex文件里面.Dex是一个类似Jar的存储了多有Java编译字节码的归档文件.因为Android系统使用Dalvik虚拟机,所以需要把使用 ... 
- 程序员必备:Oracle日常维护命令
			上一篇讲了Linux的日常维护命令,这篇讲讲Oracle的日常维护命令.工作中需要使用Oracle数据库的童鞋们,相信或多或少都需要对Oracle做一些基本的维护操作,例如导入导出总该有吧?( ... 
- 【Unity Shaders】学习笔记——SurfaceShader(四)用纹理改善漫反射
			[Unity Shaders]学习笔记——SurfaceShader(四)用纹理改善漫反射 转载请注明出处:http://www.cnblogs.com/-867259206/p/5603368.ht ... 
- 【PL/SQL练习】函数
			1.必须返回一个值2.只能在表达式调用 SQL> create or replace function fun1 return number is v_sum_sal emp.sal%type; ... 
- The str method
			__str__ is a special method name, like __init__, that is supposed to return a string representation ... 
- django 单独测试模块
			今天单独测试django的一个views文件,出现错误import的模块没有定义,这个模块是在django项目中自己编写的,解决办法: 1../manage.py shell 通过命令行进去加载,再执 ... 
- Hyper-V下安装Ossim系统
			WindowsServer2008Hyper-V下安装Ossim系统 背景:很多朋友在用Hyper-v安装Linux的时候总是抱怨速度很慢,而且装好了系统无法识别网卡,可实际上针对网卡的问题本文提出了 ... 
