L1-003. 个位数统计
给定一个k位整数N = dk-1*10k-1 + ... + d1*101 + d0 (0<=di<=9, i=0,...,k-1, dk-1>0),请编写程序统计每种不同的个位数字出现的次数。例如:给定N = 100311,则有2个0,3个1,和1个3。
输入格式:
每个输入包含1个测试用例,即一个不超过1000位的正整数N。
输出格式:
对N中每一种不同的个位数字,以D:M的格式在一行中输出该位数字D及其在N中出现的次数M。要求按D的升序输出。
输入样例:100311
输出样例:0:2
1:3
3:1
正确答案:
#include<bits/stdc++.h>
using namespace std;
char num[1000];
int main()
{
int a[10] = { 0 }, i = 0;
cin>>num;
while (num[i]-'0'>= 0)
{
a[num[i]-'0']++;
i++;
}
for (i = 0; i<=9; i++)
{
if(a[i])
printf("%d:%d\n", i, a[i]);
}
return 0;
}
#include<bits/stdc++.h>
using namespace std;
int main()
{
long long n;
int num,i;
int count[10002]={0};
cin>>n;
while(n)
{
num=n%10;
count[num]++;
n=n/10;
}
for(i=0;i<=9;i++)
{
if(count[i]!=0)
printf("%d:%d\n",i,count[i]);
}
return 0;
}

本文介绍了一道关于统计一个不超过1000位的正整数中不同个位数字出现次数的问题,并提供了两种C++代码实现方案。一种使用字符数组进行处理,另一种采用整数循环处理。通过对比指出了使用字符数组更符合题目要求。
595

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



