附上力扣原题链接https://leetcode-cn.com/problems/to-lower-case/
1.常规法
遍历字符串,将大写的字母ASCII码加上32,小写字母ASCII码减去32即可。
#include<iostream>
#include<string>
using namespace std;
class Solution {
public:
string toChangeCase(string str) {
for (int i = 0; i < str.size(); i++)
{
//大转小
if (str[i] >= 65 && str[i] <= 90)
{
str[i] += 32;
}
//小转大
else if (str[i] >= 97 && str[i] <= 122)
{
str[i] -= 32;
}
}
return str;
}
};
int main()
{
Solution s;
string str = "HELLOhello";
cout << s.toChangeCase(str) << endl;
return 0;
}
2.针对于字符的函数法
遍历字符串,通过tolower(char c)和toupper(char c)两个方法将字符串中的字符进行转换。
#include<iostream>
#include<string>
using namespace std;
class Solution {
public:
string toChangeCase(string str) {
for (int i = 0; i < str.size(); i++)
{
//大转小
if (str[i] >= 65 && str[i] <= 90)
{
str[i]=tolower(str[i]);
}
//小转大
else if (str[i] >= 97 && str[i] <= 122)
{
str[i]=toupper(str[i]);
}
}
return str;
}
};
int main()
{
Solution s;
string str = "HELLOhello";
cout << s.toChangeCase(str) << endl;
return 0;
}
3.位运算法
依旧遍历字符串,利用位运算技巧。
大写变小写、小写变大写 : 字符 ^= 32;
大写变小写、小写变小写 : 字符 |= 32;
小写变大写、大写变大写 : 字符 &= -33;
#include<iostream>
#include<string>
using namespace std;
class Solution {
public:
string toChangeCase(string str) {
for(auto &i : str){
i |= 32;
}
return str;
}
};
int main()
{
Solution s;
string str = "HELLOhello";
cout << s.toChangeCase(str) << endl;
return 0;
}
4.头文件algorithm中的transform方法
transform(str.begin(),str.end(),str.begin(),::tolower);//大写转小写
transform(str.begin(),str.end(),str.begin(),::toupper);//小写转大写
#include<iostream>
#include<string>
using namespace std;
#include<algorithm>
class Solution {
public:
string toLowerCase(string str) {
transform(str.begin(), str.end(), str.begin(), ::tolower);
return str;
}
string toUpperCase(string str) {
transform(str.begin(), str.end(), str.begin(), ::toupper);
return str;
}
};
int main()
{
Solution s;
string str1 = "HELLOhello";
string str2 = "HELLOhello";
cout << s.toLowerCase(str1) << endl;
cout << s.toUpperCase(str2) << endl;
return 0;
}