[NOIP2018 普及组] 标题统计
题目描述
凯凯刚写了一篇美妙的作文,请问这篇作文的标题中有多少个字符? 注意:标题中可能包含大、小写英文字母、数字字符、空格和换行符。统计标题字 符数时,空格和换行符不计算在内。
输入格式
输入文件只有一行,一个字符串 s s s。
输出格式
输出文件只有一行,包含一个整数,即作文标题的字符数(不含空格和换行符)。
样例 #1
样例输入 #1
234
样例输出 #1
3
样例 #2
样例输入 #2
Ca 45
样例输出 #2
4
提示
【输入输出样例 1 说明】
标题中共有 3 个字符,这 3 个字符都是数字字符。
【输入输出样例 2 说明】 标题中共有$ 5$ 个字符,包括 1 1 1 个大写英文字母, 1 1 1 个小写英文字母和 2 2 2 个数字字符, 还有 1 1 1 个空格。由于空格不计入结果中,故标题的有效字符数为 4 4 4 个。
【数据规模与约定】
规定
∣
s
∣
|s|
∣s∣ 表示字符串
s
s
s 的长度(即字符串中的字符和空格数)。
对于
40
%
40\%
40% 的数据,
1
≤
∣
s
∣
≤
5
1 ≤ |s| ≤ 5
1≤∣s∣≤5,保证输入为数字字符及行末换行符。
对于
80
%
80\%
80% 的数据,
1
≤
∣
s
∣
≤
5
1 ≤ |s| ≤ 5
1≤∣s∣≤5,输入只可能包含大、小写英文字母、数字字符及行末换行符。
对于
100
%
100\%
100% 的数据,
1
≤
∣
s
∣
≤
5
1 ≤ |s| ≤ 5
1≤∣s∣≤5,输入可能包含大、小写英文字母、数字字符、空格和行末换行符。
所需变量
char temp;//用于接收每一个字符,因为我是一个字符一个字符的处理,所以不需要用字符串数组来存储他
int sum = 0;//用于累加得到字符过的个数
首先我们一个一个输入进来,判断是否是回车,如果是回车那么就是终止输入,如果是空格我们就跳过不计算在内,如果是其他的我们就直接让sum++,因为这就是我们要计算的个数。直到输入结束我们就得到总数了,这样我们在输出sum就得到最终结果。
该算法本人认为比较优,如果有更好的想法,欢迎q我!
#include<stdio.h>
#include<stdbool.h>
int main(){
char temp;
int sum = 0;
while(~scanf("%c",&temp)){
if(temp == '\n'){
break;
}
if(temp == ' '){
continue;
}
sum++;
}
printf("%d",sum);
return 0;
}