HDU-汉字统计

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,则累加计数,最后输出计数之和的一半就是汉字的个数。

猜你喜欢

转载自blog.csdn.net/qq_41998938/article/details/83246899