1 给定一个单词,你需要判断单词的大写使用是否正确。我们定义,在以下情况时,单词的大写用法是正确的:全部字母都是大写,比如"USA"。单词中所有字母都不是大写,比如"leetcode"。如果单词不只含有一个字母,只有首字母大写, 比如 "Google"。否则,我们定义这个单词没有正确使用大写字母。
示例 1:
输入: "USA"
输出: True
示例 2:
输入: "FlaG"
输出: False
注意: 输入是由大写和小写拉丁字母组成的非空单词。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/detect-capital
题解:
class Solution {
public:
bool detectCapitalUse(string word) {
const char *w = word.c_str();
int i=0,up=0;
bool number1=false;
for(int i=0;i<=word.length();i++)
{
if(w[i]>=65&&w[i]<=90)
{
up++;
if(i==0)
number1=true;
}
}
if(up==word.length()||up==0||(up==1&&number1==true))
return true;
return false;
}
};
此题比较简单,对于c++而言涉及常量型字符串指针,字符串长度获取。
解题思路:定义一个const char* 类型的变量 w 其实就是定义一个数组。然后将所有string类型变量里的字符挨个放入w数组。最后一层for循环对其进行遍历,记录大写字母的个数和一个首字母是否为大写的bool型变量。遍历完成以后判断大写字母个数首字母大写的标志就行了。