汉字统计
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 38443 Accepted Submission(s): 20969
Problem Description
统计给定文本文件中汉字的个数。
Input
输入文件首先包含一个整数n,表示测试实例的个数,然后是n段文本。
Output
对于每一段文本,输出其中的汉字的个数,每个测试实例的输出占一行。
[Hint:]从汉字机内码的特点考虑~
[Hint:]从汉字机内码的特点考虑~
Sample Input
2 WaHaHa! WaHaHa! 今年过节不说话要说只说普通话WaHaHa! WaHaHa! 马上就要期末考试了Are you ready?
Sample Output
14 9
Author
lcy
Source
Recommend
从汉字机内码的角度考虑,汉子机内码都是占两个字节且每个字节的第一个二进制位都是0,就是都为负数,除2就是汉字个数。
#include<stdio.h>
#include<string.h>
int main() {
int n;
char c;
scanf("%d",&n);
getchar();
while(n--) {
int k=0;
while((c=getchar())!='\n')
if(c<0)
k++;
printf("%d\n",k/2);
}
return 0;
}

本文介绍了一个简单的程序设计问题——如何统计文本文件中的汉字数量。通过分析汉字机内码的特点,即每个汉字占用两个字节且高位均为1,设计了一种有效的统计方法。文章提供了一个示例程序,该程序读取文本并输出汉字总数。
651

被折叠的 条评论
为什么被折叠?



