汉字统计
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 64694 Accepted Submission(s): 34811
Problem Description
统计给定文本文件中汉字的个数。
Input
输入文件首先包含一个整数n,表示测试实例的个数,然后是n段文本。
Output
对于每一段文本,输出其中的汉字的个数,每个测试实例的输出占一行。
[Hint:]从汉字机内码的特点考虑~
Sample Input
2
WaHaHa! WaHaHa! 今年过节不说话要说只说普通话WaHaHa! WaHaHa!
马上就要期末考试了Are you ready?
Sample Output
14
9
题解:这道题显然是一道水题,只是这里出现汉字机内码问题才是问题显得有点难
下面是我看大佬的代码有所启发,其中有注解
#include<stdio.h>
#include<string.h>
char a[10000];
int main()
{
int n,m,i;
scanf("%d",&n);
getchar(); //这个不能少,读取缓存中的回车,不然会出现乱码,或者答案错误!
while(n--)
{
m=0;
gets(a);
int l=strlen(a);
for( i=0; i<l; i++)
{
if(a[i]<0||a[i]>126) //重点在于这里当不在0~126之间时就显然是汉字了
m++;
}
printf("%d\n",m/2); //由于每个汉字都有两个字节,所以要除以2
}
}
小白心得