520. Detect Capital(C++)

题目:

Given a word, you need to judge whether the usage of capitals in it is right or not.

We define the usage of capitals in a word to be right when one of the following cases holds:

  1. All letters in this word are capitals, like “USA”.
  2. All letters in this word are not capitals, like “leetcode”.
  3. Only the first letter in this word is capital if it has more than one letter, like “Google”.

Otherwise, we define that this word doesn’t use capitals in a right way.

Example 1:
Input: "USA"
Output: True
Example 2:
Input: "FlaG"
Output: False

Note: The input will be a non-empty word consisting of uppercase and lowercase latin letters.

class Solution {
public:
    bool detectCapitalUse(string word) {

    }
};

翻译:

检测资本
给定一个词,你需要判断它中的资本的使用是否正确。

当以下情况之一存在时,我们将单词中资本的使用定义为正确:

  1. 这个单词中的所有字母都是大写,如“USA”。
  2. 这个单词中的所有字母都不是大写,例如“leetcode”。
  3. 只有此字中的第一个字母是大写,如果它有多个字母,如“Google”。
    否则,我们定义这个词不以正确的方式使用大写。

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

解析:

这就是一个要求不断实现几个要实现的条件的题,重点是要如何去设置条件。

遇到多条件的,我的通常做法是:先把条件列下来,然后看哪些条件可以归类,成为同一组,或者说用一个表达式表示多个条件,这样就可以达到间接的目的。

  1. 都是大写
  2. 都是小写
  3. 如果有多个字母,头字母大写

合并:
首先判断是不是一个字母,则不论大小写都符合,
。。。。。

解答:

class Solution {
public:
    bool detectCapitalUse(string word) {
        if (word.length() <= 1) 
        return true;
        if (islower(word[0]) || (isupper(word[0]) && islower(word[1])))
        {
            for (int i = 1; i < word.length(); i++)
                if (isupper(word[i])) 
                return false;
        } 
        else 
        {
            for (int i = 1; i < word.length(); i++)
                if (islower(word[i])) 
                return false;
        }
        return true;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值