LeetCode | 检测大写字母 问题 | C++
我们定义,在以下情况时,单词的大写用法是正确的:
- 全部字母都是大写,比如 “USA” 。
- 单词中所有字母都不是大写,比如 “leetcode” 。
- 如果单词不只含有一个字母,只有首字母大写,比如 “Google” 。
给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。示例 1:
输入:word = “USA” 输出:true
示例 2:输入:word = “FlaG” 输出:false
提示:
1 <= word.length <= 100
word 由小写和大写英文字母组成
- 自己解决
#include <iostream>
#include <string>
#include <cctype>
using namespace std;
bool allUpper(string word)
{
for (char c : word)
{
if (std::isupper(c))
{
continue;
}
else
{
return false;
}
}
return true;
}
bool allLower(string word)
{
for (char c : word)
{
if (std::islower(c))
{
continue;
}
else
{
return false;
}
}
return true;
}
bool CapitalizeFirst(string word)
{
if (std::isupper(word.at(0)))
{
for (int i = 1; i < word.size(); i++)
{
if (!std::islower(word.at(i)))
{
return false;
}
}
return true;
}
// 首字母不是大写,不符合条件!
return false;
}
bool detectCapitalUse(string word)
{
int flag_1 = allUpper(word);
int flag_2 = allLower(word);
int flag_3 = CapitalizeFirst(word);
if (flag_1 || flag_2 || flag_3)
{
return true;
}
else
{
return false;
}
}
int main()
{
string input;
while (getline(std::cin, input))
{
bool cap = detectCapitalUse(input);
cout << (cap ? "true" : "false");
system("pause");
}
return 0;
}
- 官方题解
#include <iostream>
#include <string>
using namespace std;
/*
根据题目要求,若单词的大写用法正确,则需要满足:
(1) 若第 1 个字母为大写,则其他字母必须均为大写或均为小写,即其他字母必须与第 2 个字母的大小写相同;
(2) 若第 1 个字母为小写,则其他字母必须均为小写。
*/
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++)
{
/*
异或^
相同取0,相异取1
A | B | A XOR B
0 | 0 | 0
0 | 1 | 1
1 | 0 | 1
1 | 1 | 0
*/
if (islower(word[i]) ^ islower(word[1]))
return false;
}
return true;
}
int main()
{
string input;
while (getline(std::cin, input))
{
bool cap = detectCapitalUse(input);
cout << (cap ? "true" : "false");
system("pause");
}
return 0;
}