我们定义,在以下情况时,单词的大写用法是正确的:
- 全部字母都是大写,比如 "USA" 。
- 单词中所有字母都不是大写,比如 "leetcode" 。
- 如果单词不只含有一个字母,只有首字母大写, 比如 "Google" 。
给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。
示例 1:
输入:word = "USA"
输出:true
方法一:分治
由题分析可得上述三种正确的单词格式可以归类为一下三种:
- 首字母大写
- 其余字母全小写
- 其余字母全大写
- 首字母小写 其余字母全小写
基于此点我们可以设置两个标记变量记录首字母和第二个字母的大小写情况,并通过首字母的大小写对情况进行区分筛选。
public boolean detectCapitalUse(String word) {
if (word.length() < 2) return true;
char[] chars = word.toCharArray();
boolean upper = isBig(chars[0]), second = isBig(chars[1]);
for (int i = 1; i < chars.length; ++ i) {
char c = chars[i];
if (upper) {
if (second != isBig(c)) {
return false;
}
} else if (isBig(c)) return false;
}
return true;
}
private static boolean isBig(char c) {
return 'A' <= c && c <= 'Z';
}