因为首字母可以和第二个字母不一样,所以从第二个字母开始检测之后的字母是否一致就可以了。但是需要排除首字母是小写之后是大写的情况。
class Solution {
public:
bool detectCapitalUse(string word) {
if ((word[1] >= 65) && (word[1] <= 90) && (word[0] >= 97) && (word[0] <= 122)) return false;
else
{
if ((word[1] >= 65) && (word[1] <=90))
{
for (int i = 2; i < word.length(); i++)
if ((word[i] < 65) || (word[i] > 90)) return false;
}
if ((word[1] >= 97 ) && (word[1] <= 122))
{
for (int i = 2; i < word.length(); i++)
if ((word[i] < 97) || (word[i] > 122)) return false;
}
}
return true;
}
};看了一下最佳答案的C++解法感觉没意思,参考java的写了一个简单的,速度比我自己的快。
思路是统计字符串里所有的大写字母个数,符合标准的要么是0个要么是word.length个,要么是1个且在首字母。判断大小写直接可以用字符相减作比较。
class Solution {
public:
bool detectCapitalUse(string word) {
int cnt = 0;
for (int i = 0; i < word.length(); i++)
if ('Z' - word[i] >= 0) cnt++;
return ((cnt == 0 || cnt == word.length()) || (cnt == 1 && 'Z' - word[0] >= 0));
}
};
本文提供了一种使用C++检查单词大小写格式的有效方法。通过统计大写字母的数量来判断单词是否符合大写规则:全大写、全小写或仅首字母大写。文章包含两个实现方案,分别展示了不同的逻辑处理方式。
1295

被折叠的 条评论
为什么被折叠?



