我们定义,在以下情况时,单词的大写用法是正确的:
全部字母都是大写,比如 "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; } };