问题描述:
我们定义,在以下情况时,单词的大写用法是正确的:
全部字母都是大写,比如 “USA” 。
单词中所有字母都不是大写,比如 “leetcode” 。
如果单词不只含有一个字母,只有首字母大写, 比如 “Google” 。
给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。
问题分析:
示例 1:
输入:word = “USA”
输出:true
示例 2:
输入:word = “FlaG”
输出:false
问题求解:
class Solution {
public boolean detectCapitalUse(String word) {
char[] cs = word.toCharArray();
int upper = 0;//大写字母个数
int lower = 0;//小写字母个数
for(int i=0;i<cs.length;i++) {
if(cs[i]>='a') {
lower++;
}else {
upper++;
}
}
if(upper==cs.length) { //全大写
return true;
}
if(lower==cs.length) {//全小写
return true;
}
if(upper==1 && cs[0]<'a') {//首字母大写
return true;
}
return false;
}
}
问题总结:
老规矩先看一下官方求解。
方法一:根据题目要求实现
思路和算法
根据题目要求,若单词的大写用法正确,则需要满足:
若第 11 个字母为大写,则其他字母必须均为大写或均为小写,即其他字母必须与第 22 个字母的大小写相同;
若第 11 个字母为小写,则其他字母必须均为小写。
根据以上规则,可以整理得到以下更简单的判断规则:
无论第 11 个字母是否大写,其他字母必须与第 22 个字母的大小写相同;
若第 11 个字母为小写,则需额外判断第 22 个字母是否为小写。
作者:LeetCode-Solution
链接:https://leetcode-cn.com/problems/detect-capital/solution/jian-ce-da-xie-zi-mu-by-leetcode-solutio-449z/
来源:力扣(LeetCode)