每日一题2023.11.26——各位数统计【PTA】

题目要求:

d6c50d382e064606b38fa846c41e85bf.png

输入格式:

每个输入包含 1 个测试用例,即一个不超过 1000 位的正整数 N。

输出格式:

 N 中每一种不同的个位数字,以 D:M 的格式在一行中输出该位数字 D 及其在 N 中出现的次数 M。要求按 D 的升序输出。

输入样例:

100311

输出样例:

0:2
1:3
3:1

思路: 

1.先定义一个字符串n

2.在一个for循环中n[i]代表这一串字符的每一个字符,使用n[i]-'0'将输入的字符转化为数字形式、

3.定义一个整型数组x[1000],并且初始化为0

4.循环遍历i将x[n[i]-'0']进行++操作

5.最后判断x[n[i]-'0']是否为0,不为0的输出i值和x[i];

注意:这里输入整数不要定义整型,因为定义int型的话,int型是有范围的,如果数太大的话会溢出,没有办法统计后面的数字。

代码:

#include

using namespace std;

int main()
{
    string n;
    cin >> n;
    int x[1000] = {0};
    for(int i = 0; i < n.size(); i++)
    {
        x[n[i] - '0'] ++;
    }

    for(int i = 0; i < 10; i ++)
    {
        if(x[i] != 0)
            cout << i << ":" << x[i] << endl;
    }
   
    
    return 0;
}

测试结果:

 每日一题2023.11.26——各位数统计【PTA】_第1张图片

 

你可能感兴趣的:(每日一题C/C++,算法,pta,每日一题,C++,练习题)