二. 字符串_字符_520. 检测大写字母

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

全部字母都是大写,比如 “USA” 。
单词中所有字母都不是大写,比如 “leetcode” 。
如果单词不只含有一个字母,只有首字母大写, 比如 “Google” 。
给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。

示例 1:

输入:word = “USA”
输出:true
示例 2:

输入:word = “FlaG”
输出:false

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/detect-capital

这里定义了规则:
都大写或者都小写,或者第一个字母是大写的那么是合格的,其他的都不是合格的
1.检查所有字符的大小写
2.记录大写字母的个数
3.这里如果只有一个大写的,而且第一个字母不是大写的那么返回false
注:这里看了官网的注释A和Ab这两种写法都是正确的,所以只要有一个字母是大写的不用单独检查字母的长度

bool detectCapitalUse(string word) {
    int len = word.size();
    int capital_len = 0;

    //这里主要找到大写字母的数量
    for(int i = 0; i < len; i++) {
        if(word[i] >= 65 && word[i] <= 90) {
            capital_len++;
        }
    }

    //若大写字母只有一个的时候,必须检查首写字母为大写
    if(capital_len == 0 || capital_len == len || (capital_len == 1 && word[0] >= 65 && word[0] <= 90)) {
        return true;
    } else {
        return false;
    }
}

上面的步骤还可以精简,如下形式:
1.正确情况下,一般有如下形式:abc,ABC,Abc
2.这里可以看出来第二个字母和第三个字母的大小写是相同的,正确的情况下
3.特殊情况是aBC,这种情况下是不正确的,而后面的是小写,则第一个是什么都行。
4.所以这里先要用判断排除这种情况,剩下就是检查剩下每个字母的大小写是否相同

bool detectCapitalUse(string word) {
    int m = word.size();

    //将特殊条件特殊处理
    //判断是否为大写或是否为小写
    if(m >= 2 && islower(word[0]) && isupper(word[1])) {
        return false;
    }

    int i = 2;

    //这里只要islower返回结果相同即可
    while(i < m) {
        if(islower(word[i]) != islower(word[i - 1])) {
            return false;
        }

        i++;
    }

    return true;
}
int main() {
    bool flag = detectCapitalUse("USA");
    cout << flag << endl;
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值