520. 检测大写字母
题目描述
我们定义,在以下情况时,单词的大写用法是正确的:
- 全部字母都是大写,比如
"USA"
。 - 单词中所有字母都不是大写,比如
"leetcode"
。 - 如果单词不只含有一个字母,只有首字母大写, 比如
"Google"
。
给你一个字符串 word
。如果大写用法正确,返回 true
;否则,返回 false
。
示例 1:
输入:word = "USA" 输出:true
示例 2:
输入:word = "FlaG" 输出:false
提示:
1 <= word.length <= 100
word
由小写和大写英文字母组成
解法
方法一:统计大写字母的个数
我们可以统计字符串中大写字母的个数,然后根据大写字母的个数判断是否符合题目要求。
- 如果大写字母的个数为 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 |
|