zoukankan      html  css  js  c++  java
  • 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.

    1.【基础知识】

    回文字符串是一个正读和反读都一样的字符串,比方“level”或者“noon”等等就是回文串。
    2.【屌丝代码】

    class Solution {
    public:
        bool isPalindrome(string s) 
    	{
            int m(0);
    		char a[100]={'0'};
    		if(s.size()==0)
    			return true;
    		for(int k =0;k<s.length();k++)
    		{
    			if((s[k]<='z'&&s[k]>='a')||(s[k]>='A'&&s[k]<='Z'))
    				a[m++] = s[k];
    		}
    		a[m] = '';
    		int i(0),j(strlen(a)-1);
    		while(j>i)
    		{
    			if((a[i]!=a[j])&&(a[i]-a[j]!=32)&&(a[i]-a[j]!=-32))
    				return false;
    				i++;
    				j--;
    		}
    		return true;
        }
    };

    【屌丝AC源代码】

    #include<iostream>  
    #include<string>  
      
    using namespace std;  
      
    class Solution {  
    public:  
        bool isPalindrome(string s)   
        {  
            int m(0);  
            if(s.size()==0)  
                return true;          
            char *a = new char[s.size()-1];  
            for(int k = 0;k<s.length();k++)  
            {  
                if((s[k]<='z'&&s[k]>='a')||(s[k]>='A'&&s[k]<='Z')||(s[k]>='0'&&s[k]<='9'))  
                    a[m++] = s[k];  
    //          if(m>240)  
    //              cout<<m<<endl;  
            }  
    //      cout<<a<<endl;  
            a[m] = '';  
    //      cout<<a<<endl;  
            int i(0),j(m-1);  
            while(j>i)  
            {  
                if(((a[i]<='z'&&a[i]>='a')||(a[i]>='A'&&a[i]<='Z'))&&((a[j]<='z'&&a[j]>='a')||(a[j]>='A'&&a[j]<='Z')))  
                    if((a[i]!=a[j])&&((a[i]-a[j]!=32)&&(a[i]-a[j]!=-32)))  
                        return false;  
                    else  
                    {     
                        i++;j--;continue;  
                    }  
                if(a[i]!=a[j])  
                    return false;  
                i++;  
                j--;  
                      
            }  
            return true;  
        }  
    };  
      
    int main()  
    {  
    /*  
        cout<<sizeof(int)/sizeof(char)<<endl; 
        cout<<sizeof(unsigned int)/sizeof(char)<<endl; 
        cout<<sizeof(long int)/sizeof(char)<<endl; 
        cout<<sizeof(double)/sizeof(char)<<endl; 
    */    
    //  string mystr = "tyQZrD2 7UL91z,i`O2ef:6e'2"yP !:,U.:pX90PU3CXo'i!;3 `j 0?"'hK8 ? BAjM2"DBw?7!4R3?U2E8F2y!?

    3 R2!fw 6e!:0 ErCi98KM`,8`8648,mi3P0`,!5 E.?00J3A 52"x8,tHy!'2!DLBbK'j!tt1C' 7`JPulW""uRTbr"',",U`ZOW5'"LMDQDMJ"'5WOZ`U,",'"rbTRu""WluPJ`7 'C1tt!j'KbBJD!2'!yHt,8x"25 A3J00?.E 5!,`0P3im,8468`8,`MK89iCrE 0:!e6 wf!2R 3?!y2F8E2U?

    3R4!7?wBD"2MjAB ? 8Kh'"?0 j` 3;!i'oXC3UP09Xp:.U,:! Py"2'e6:fe2O`i,z19LU7 2DrZQyt"; string mystr = "ab2A"; Solution my; cout<<my.isPalindrome(mystr)<<endl; /* cout<<mystr.size()<<endl; cout<<mystr[0]<<endl; cout<<mystr[mystr.size()-1]<<endl; */ return 0; }

    
    3.【AC源代码】
    

    class Solution 
    {
    public:
    	bool isPalindrome(string s) 
    	{
    		transform(s.begin(), s.end(), s.begin(), ::tolower);// 字符串所有改为小写输出到 s 之中
    		auto left = s.begin();
    		auto right = prev(s.end());
    		while (left < right) 
    		{
    			if (!::isalnum(*left)) 
    			{	++left;
    				continue;}
    			if (!::isalnum(*right)) 
    			{	--right;
    				continue;}
    			if (*left != *right) 
    			    return false;
    			else{ left++, right--; }
    		}
    		return true;
    	}
    };
    
    
    
    
    
    
    
    4.【复盘】
    

    1.失误点:considering only alphanumeric characters and ignoring cases 理解为回文的约束为字符且忽略其大写和小写。alphanumeric characters原意是数组和字符的,没考虑到数字导致直接实现存在问题;

    2.transform 使用方法详见文章 简单的程序诠释C++ STL算法系列之十八:transform 

    详址:http://blog.csdn.net/jerryjbiao/article/details/7523110

    3.autokeywordauto对象和变量被存储在栈中,它的生命周期仅存在于它的声明所在的块(block)中。

    在块中定义的块假设不加其他的修饰符则都是auto类型的。

    autokeyword能够省去。auto对象和变量对外部模块都是不可见的。

    详见:C/C++中涉及存储方式的keyword:auto,static,register,extern

    4.int isalnum ( int c );//检查字符是否是字母或者数字。

    详见:isalnum <ctype.h> <cctype>

    详址:http://blog.csdn.net/snowdream86/article/details/6889276
    5.定义函数:int tolower(int c);文件:#include <stdlib.h>;函数说明:若參数 c 为大写字母则将该相应的小写字母返回。

    详见 :tolower

    详址:http://blog.csdn.net/Michaelwubo/article/details/41080495

    5.【算法核心思想】

    【屌丝AC源代码】

    1)剔除字符串中非字母、数字字符;

    2)非大写和小写关系的不相等以及普通的不等构成判据;

    3)前、后向迭代比对,得到结果。

    【AC源代码】

    1)tolower方法,字符串转小写;

    2)islnum方法。滤除标点字符得到推断;

    3)前、后向迭代比对,得到结果。

  • 相关阅读:
    EML格式解析及其访问实现
    Windows Live Writer测试
    这几天为搬房子的事烦死了。
    今天装MSSQL2005时发现有些安装文件要跟2000共享(无法更改安装盘符)
    今天看到一段比较有意思的JS脚本,根据访问速度来选择镜像。
    MS的帮助越来越多视频了。
    邹健写的公交车路线查询(包括转车近到远排列)。
    今天终于搬到这边住了,就是感觉贵了点。
    第一次看到银行系统用DotNet来做。
    这几天上火了
  • 原文地址:https://www.cnblogs.com/jhcelue/p/6816766.html
Copyright © 2011-2022 走看看