杭电2030 汉字统计

因为不知道所要输入的一行字符串会有多长则不能通过定义一个字符数组来接受所输入的一行字符,可以通过e=getchar())!='\n'语句来不停的接收字符,并且边接收边判断if(e<0)如果小于0则表明接收的是一个汉字的一半(汉字占两个字符),然后计数器加一,最终汉字的个数是计数器值得意半!!

Problem Description
统计给定文本文件中汉字的个数。
 Input
输入文件首先包含一个整数n,表示测试实例的个数,然后是n段文本。
 Output
对于每一段文本,输出其中的汉字的个数,每个测试实例的输出占一行。
[Hint:]从汉字机内码的特点考虑~
Sample Input
2 WaHaHa! WaHaHa! 今年过节不说话要说只说普通话WaHaHa! WaHaHa! 马上就要期末考试了Are you ready?
 Sample Output
14 9

代码:

#include<stdio.h>

int main()
{
 int n;
 scanf("%d",&n);
 getchar();
 while(n--)
 {
  char e;
  int sum=0;
  while((e=getchar())!='\n')
  {
   if(e<0)
      sum++;
  }
  printf("%d\n",sum/2);
 }
 return 0;
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章