描述
找出给定字符串中大写字符(即'A'-'Z')的个数。
数据范围:字符串长度:1\le |s|\le 250\1≤∣s∣≤250
字符串中可能包含空格或其他字符
进阶:时间复杂度:O(n)\O(n) ,空间复杂度:O(n)\O(n)
输入描述:
对于每组样例,输入一行,代表待统计的字符串
输出描述:
输出一个整数,代表字符串中大写字母的个数
示例1
输入:
A 1 0 1 1150175017(&^%&$vabovbaoadd 123#$%#%#O
输出:
2
代码
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<ctype.h>
int main()
{
char str[250];
gets(str);
int i =0;
int num = 0;
while(str[i] != '\0') {
if(isupper(str[i])){
num++;
}
i++;
}
printf("%d",num);
}
这个题主要就是isupper的运用,没什么考点
以后字符串尽量用gets直接读入,一开始用scanf("%[^\n]",str)读入,结果测试用例的字符串有个\n,导致用例过不了
再复习下判断大小写函数
int isupper(int c);
int islower(int c);
头文件 #include<ctype.h>