520_检测大写字母_2021.11.13

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

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

 

 

又变成室友的形状了,本来自己思考的话可以跟着官方的思路走的,以下是室友形状式的代码:

(特别指出,学习了C++整体字符串转大小写的方法,但是还是感觉挺麻烦的,不如其他语言方便)

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

        string lowStr(word.length(),' ');
        string upperStr(word.length(), ' ');

        transform(word.begin(), word.end(), lowStr.begin(), ::tolower);
        transform(word.begin(), word.end(), upperStr.begin(), ::toupper);

        if (word == upperStr || word == lowStr)
            return true;

        lowStr[0] -= 32;
        if (word == lowStr)
            return true;

        return false;
    }
};

 

题解答案:

class Solution {
public:
    bool detectCapitalUse(string word) {
        // 若第 1 个字母为小写,则需额外判断第 2 个字母是否为小写
        if (word.size() >= 2 && islower(word[0]) && isupper(word[1])) {
            return false;
        }
        
        // 无论第 1 个字母是否大写,其他字母必须与第 2 个字母的大小写相同
        for (int i = 2; i < word.size(); ++i) {
            if (islower(word[i]) ^ islower(word[1])) {
                return false;
            }
        }
        return true;
    }
};

 

posted @ 2021-11-13 12:36  炫迈吃到爽  阅读(27)  评论(0编辑  收藏  举报