520. 检测大写字母
题目描述
我们定义,在以下情况时,单词的大写用法是正确的:
- 全部字母都是大写,比如 
"USA"。 - 所有字母都不是大写,比如 
"leetcode"。 - 只有首字母大写, 比如 
"Google"。 
给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。
示例 1:
输入:word = "USA" 输出:true
示例 2:
输入:word = "FlaG" 输出:false
提示:
1 <= word.length <= 100word由小写和大写英文字母组成
解法
方法一:统计大写字母的个数
我们可以统计字符串中大写字母的个数,然后根据大写字母的个数判断是否符合题目要求。
- 如果大写字母的个数为 0 或者等于字符串的长度,那么返回 
true。 - 如果大写字母的个数为 1 并且第一个字母是大写字母,那么返回 
true。 - 否则返回 
false。 
时间复杂度 \(O(n)\),其中 \(n\) 为字符串 word 的长度。空间复杂度 \(O(1)\)。
1 2 3 4  |  | 
1 2 3 4 5 6 7 8 9 10 11 12  |  | 
1 2 3 4 5 6 7  |  | 
1 2 3 4 5 6 7 8 9  |  | 
1 2 3 4  |  |