题目描述
我们定义,在以下情况时,单词的大写用法是正确的:
全部字母都是大写,比如 “USA” 。
单词中所有字母都不是大写,比如 “leetcode” 。
如果单词不只含有一个字母,只有首字母大写, 比如 “Google” 。
给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。
示例 1:
输入:word = “USA”
输出:true
示例 2:
输入:word = “FlaG”
输出:false
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/detect-capital
这里定义了规则:
都大写或者都小写,或者第一个字母是大写的那么是合格的,其他的都不是合格的
1.检查所有字符的大小写
2.记录大写字母的个数
3.这里如果只有一个大写的,而且第一个字母不是大写的那么返回false
注:这里看了官网的注释A和Ab这两种写法都是正确的,所以只要有一个字母是大写的不用单独检查字母的长度
bool detectCapitalUse(string word) {
int len = word.size();
int capital_len = 0;
//这里主要找到大写字母的数量
for(int i = 0; i < len; i++) {
if(word[i] >= 65 && word[i] <= 90) {
capital_len++;
}
}
//若大写字母只有一个的时候,必须检查首写字母为大写
if(capital_len == 0 || capital_len == len || (capital_len == 1 && word[0] >= 65 && word[0] <= 90)) {
return true;
} else {
return false;
}
}
上面的步骤还可以精简,如下形式:
1.正确情况下,一般有如下形式:abc,ABC,Abc
2.这里可以看出来第二个字母和第三个字母的大小写是相同的,正确的情况下
3.特殊情况是aBC,这种情况下是不正确的,而后面的是小写,则第一个是什么都行。
4.所以这里先要用判断排除这种情况,剩下就是检查剩下每个字母的大小写是否相同
bool detectCapitalUse(string word) {
int m = word.size();
//将特殊条件特殊处理
//判断是否为大写或是否为小写
if(m >= 2 && islower(word[0]) && isupper(word[1])) {
return false;
}
int i = 2;
//这里只要islower返回结果相同即可
while(i < m) {
if(islower(word[i]) != islower(word[i - 1])) {
return false;
}
i++;
}
return true;
}
int main() {
bool flag = detectCapitalUse("USA");
cout << flag << endl;
return 0;
}