文章目录
- 1.string类介绍
- 2.字符大小写转换与判断常用函数
- 2.1 字符大小写判断
- 2.1.1 isalpha()
- 2.1.2 isalnum()
- 2.1.3 islower()
- 2.1.4 isupper()
 
- 2.2 字符大小写转换
- 2.2.1 tolower()
- 2.2.2 toupper()
 
 
- 3.LeetCode例题使用示范
- 3.1例题一
- 3.1.1方法一
- 3.1.2方法二
 
- 3.2例题二
- 3.2.1方法
 
 
1.string类介绍
- string是C++标准库的一个重要的部分,主要用于字符串处理。可以使用输入输出流方式直接进行string操作,也可以通过文件等手段进行string操作。同时,C++的算法库对string类也有着很好的支持,并且string类还和c语言的字符串之间有着良好的接口。
#include <string> // 注意这里不是string.h,string.h是C字符串头文件
2.字符大小写转换与判断常用函数
- 在常用的string类字符操作时,又会经常用到大小写转换以及判断等问题,这时候就可以用相关的函数进行操作,常用的几个转换以及判断函数总结如下:
以下函数的声明在头文件<cctype>
- isalpha() 用来判断一个字符是否为字母,如果是字符则返回非零,否则返回零。
- isalnum() 用来判断一个字符是否为数字或者字母,也就是说判断一个字符是否属于a~z||A~Z||0~9。
- islower() 用来判断一个字符是否为小写字母,也就是是否属于a~z。
- isupper()和islower相反,用来判断一个字符是否为大写字母。
- tolower() 函数是把字符串都转化为小写字母。
- toupper() 函数是把字符串都转化为小写字母。
2.1 字符大小写判断
2.1.1 isalpha()
isalpha()用来判断一个字符是否为字母,如果是字符则返回非零,否则返回零。
cout<<isalpha('a'); //返回非零
cout<<isalpha('2'); //返回0
2.1.2 isalnum()
isalnum()用来判断一个字符是否为数字或者字母,也就是说判断一个字符是否属于az||AZ||0~9。
cout<<isalnum('a'); //输出非零
cout<<isalnum('2'); // 非零
cout<<isalnum('.'); // 零
2.1.3 islower()
islower()用来判断一个字符是否为小写字母,也就是是否属于a~z。
cout<<islower('a'); //非零
cout<<islower('2'); //输出0
cout<<islower('A'); //输出0
2.1.4 isupper()
isupper()和islower相反,用来判断一个字符是否为大写字母。
cout<<isupper('a'); //返回0
cout<<isupper('2'); //返回0
cout<<isupper('A'); //返回非零
2.2 字符大小写转换
2.2.1 tolower()
tolower()函数是把字符串都转化为小写字母。
string str= "THIS IS A STRING";
for (int i=0; i <str.size(); i++)
   {
   str[i] = tolower(str[i]);
   }

2.2.2 toupper()
toupper()函数是把字符串都转化为小写字母。
string str= "hahahahaha";
for (int i=0; i <str.size(); i++)
   str[i] = toupper(str[i]);

3.LeetCode例题使用示范
3.1例题一

3.1.1方法一
class Solution {
public:
    bool isPalindrome(string s) {
        string str="\0";//定义一个新的字符串
        for(int i=0;i<s.length();i++){//对字符串s进行遍历
            if(isalnum(s[i])){//isalnum判定是不是字母或者数字字符
                str += tolower(s[i]);//将大写字母转换为小写,如果不是则不动
            }
        }
        string str_rev(str.rbegin(),str.rend());//对新字符串进行反转
        if(str==str_rev)//如果反转以后的字符串和原字符串相等则返回true
        return true;
        else
        return false;
    }
};
3.1.2方法二
//更好的双指针做法。
class Solution {
public:
    bool isPalindrome(string s) {
        string str = "\0";
        int n = s.length();
        int begin = 0;
        int end = n - 1;
        while (begin < end) {
            while (begin < end && (!isalnum(s[begin]))) {
                begin++;//从前往后找符合条件的字符
            }
            while (begin < end && (!isalnum(s[end]))) {
                end--;//从后往前找符合条件的字符
            }
            if (tolower(s[begin]) != tolower(s[end]))
                return false;
            begin++;
            end--;
        }
        return true;
    }
};
3.2例题二

3.2.1方法
class Solution {
public:
    bool detectCapitalUse(string word) {
        int size=word.length();
        int Big=0;//大写字符
        int Small=0;//小写字符
        for(int i=0;i<size;i++)//先遍历字符串中的字符
        {
            if(islower(word[i]))//islower()小写字符个数
            {
                Small++;
            }
            else if(isupper(word[i]))//isupper()大写字符个数
            {
                Big++;
            }
        }
        if(Small==size||Big==size)//如果都是大写或者小写返回true
        {
            return true;
        }
        else if(Big==1&&isupper(word[0]))//如果大写只有一个且是第一个返回true
        {
            return true;
        }
        else
        return false;
    }
};