题目:520. 检测大写字母
难度: 简单
题目:
我们定义,在以下情况时,单词的大写用法是正确的:
全部字母都是大写,比如 “USA” 。
单词中所有字母都不是大写,比如 “leetcode” 。
如果单词不只含有一个字母,只有首字母大写, 比如 “Google” 。
给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。
示例1
输入:word = "USA"
输出:true
示例2
输入:word = "FlaG"
输出:false
提示:
- 1 <= word.length <= 100
- word 由小写和大写英文字母组成
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/detect-capital
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路
定义两个标志isAllBig和isAllSmall分别标记是否都为大写和是否都为小写:
- 如果
word[0]是小写,那么isAllBig = false,不可能都为大写。 - 从下标1遍历到末尾,出现大写则
isAllSmall = false,反之出现小写则isAllBig = false。 - 最后取两者的
||,但凡有一个是true说明满足情况。
注意:首字母是否大小写其实只会影响isAllBig。因为如果首字母不管是小写还是大写,只要后面的字母都是小写,就可以满足条件2或条件3。
class Solution {
public:
bool detectCapitalUse(string word) {
bool isAllBig = true, isAllSmall = true;
if (!word.empty()) {
if (word[0] >= 'a' && word[0] <= 'z') {
isAllBig = false;
}
}
for (int i = 1; i < word.size(); i++) {
if (word[i] >= 'A' && word[i] <= 'Z') {
isAllSmall = false;
} else {
isAllBig = false;//不是全部大写
}
}
//输出
return isAllSmall || isAllBig;
}
};
该博客讨论了LeetCode上的520题,即检测字符串中大写字母的正确使用。题目要求判断给定单词的大小写是否符合三个规则:全大写、全小写或仅首字母大写。提供的解题思路是通过遍历字符串,设置两个布尔变量记录全大写和全小写的状况,最后判断这两个变量来得出答案。示例中,'USA'被判为正确,而'FlaG'则不正确。

被折叠的 条评论
为什么被折叠?



