[Leetcode] 520. 检测大写字母

题目描述:


给定一个单词,你需要判断单词的大写使用是否正确。

我们定义,在以下情况时,单词的大写用法是正确的:

  1. 全部字母都是大写,比如"USA"。
  2. 单词中所有字母都不是大写,比如"leetcode"。
  3. 如果单词不只含有一个字母,只有首字母大写, 比如 "Google"。

否则,我们定义这个单词没有正确使用大写字母。

示例 1:

输入: "USA"
输出: True

示例 2:

输入: "FlaG"
输出: False

注意: 输入是由大写和小写拉丁字母组成的非空单词。

解题思路:

这个题目我的思路是,给单词设置一个值,初始值为0,单词中每遇到一个大写字母就把这个值加1,如果小写字母的话就不变,那么只有以下三种情况下大写字母的使用时对的:

1,那么如果都是小写值就为0,

2,如果都是大写那么值就是该字符串的长度,

3,如果值为1,那么看一下首字母是不是大写的,如果是也是对的。

其他情况就说明使用不对。

代码实现(Java语言):

class Solution {
    public boolean detectCapitalUse(String word) {
        char[] letters = word.toCharArray();
        int len = letters.length;
        int value = 0;
        for(int i = 0;i < len;i++){
            if(letters[i] <= 'Z' && letters[i] >= 'A'){
                value = value + 1;
            }
        }
        if(value == len || value == 0)
            return true;
        if(value == 1 && letters[0] <= 'Z' && letters[0] >= 'A')
            return true;
        return false;
    }
}


你可能感兴趣的:(leetcode字符串_简单)