Problem Description
统计给定文本文件中汉字的个数。
Input
输入文件首先包含一个整数n,表示测试实例的个数,然后是n段文本。
Output
对于每一段文本,输出其中的汉字的个数,每个测试实例的输出占一行。
[Hint:]从汉字机内码的特点考虑~
Sample Input
2
WaHaHa! WaHaHa! 今年过节不说话要说只说普通话WaHaHa! WaHaHa!
马上就要期末考试了Are you ready?
Sample Output
14
9
理解:因为不知道所要输入的一行字符串会有多长则不能通过定义一个字符数组来接受所输入的一行字符,可以通过e=(getchar())!=‘\n‘语句来不停的接收字符,并且边接收边判断if(e<0)如果小于0则表明接收的是一个汉字的一半(汉字占两个字符),然后计数器加一,最终汉字的个数是计数器值得意半!!
#include <iostream> #include<stdio.h> using namespace std; int main() { int n; cin>>n; getchar(); while(n--) {char e; int sum=0; while((e=getchar())!=‘\n‘) { if(e<0) sum++; } cout<<sum/2<<endl; } return 0; }
时间: 2024-11-08 21:21:35