hdu-汉字统计

hdu-汉字统计解题报告

Problem Description
统计给定文本文件中汉字的个数。
 

Input
输入文件首先包含一个整数n,表示测试实例的个数,然后是n段文本。
 

Output
对于每一段文本,输出其中的汉字的个数,每个测试实例的输出占一行。

[Hint:]从汉字机内码的特点考虑~

 

Sample Input
   
   
   
   
2 WaHaHa! WaHaHa! 今年过节不说话要说只说普通话WaHaHa! WaHaHa! 马上就要期末考试了Are you ready?
 

Sample Output
   
   
   
   
14 9
 

解题思想:汉字的ASCII是负数,而且一个字符是一个字节,但是汉字内码的特点是两个字节组成

代码如下:

#include<stdio.h>
#include<string.h>
char a[120];
int main()
{
    int n,len,i,j,count;
    while(~scanf("%d",&n))
    {
        getchar();
        while(n--)
        {
            gets(a);
            len=strlen(a);
            count=0;
            for(i=0;i<len;i++)
            {
                if(a[i]<0)//ASCII是小于零的
                    count++;
            }
            printf("%d\n",count/2);//因为是每两个字节一个汉字,所以要除以二
        }
    }
    return 0;
}


你可能感兴趣的:(hdu-汉字统计)