HDU-汉字统计
题目:
统计给定文本文件中汉字的个数。
Input
输入文件首先包含一个整数n,表示测试实例的个数,然后是n段文本。
Output
对于每一段文本,输出其中的汉字的个数,每个测试实例的输出占一行。
[Hint:]从汉字机内码的特点考虑~
Sample Input
2
WaHaHa! WaHaHa! 今年过节不说话要说只说普通话WaHaHa! WaHaHa!
马上就要期末考试了Are you ready?
Sample Output
14
9
#include<iostream>
#include<cstdio>
#include<string>
using namespace std;
int main()
{
int n,length,count;
string str;
scanf("%d",&n);
getchar();
while(n--)
{
getline(cin,str);
length = str.size();
count = 0;
for(int i = 0;i < length;i++)
{
if(str[i] < 0)
{
count++;
}
}
cout << count / 2 << endl;
}
return 0;
}
注意事项:
本题要计算字符串中汉字的个数,可以得知1个汉字是由2个字节组成,而一个字符只由一个字节组成。并且汉字的ASCII码是负的,所以可以遍历整个字符串,如果其值小于0,则累加计数,最后输出计数之和的一半就是汉字的个数。