
微信公众号:计算机黑科学大全
【欢迎关注微信公众号:计算机黑科学大全,对话框回复:PAT乙级真题】获取全部真题详解及代码示例
个人博客地址:https://mzwang.top
个位数统计
题目描述:
给定一个
位整数
,请编写程序统计每种不同的个位数字出现的次数。例如:给定
,则有 2 个 0,3 个 1,和 1 个 3。
输入格式:
每个输入包含 1 个测试用例,即一个不超过 1000 位的正整数
。
输出格式:
对 N 中每一种不同的个位数字,以
D:M的格式在一行中输出该位数字D及其在N中出现的次数M。要求按D的升序输出。输入样例:
100311输出样例:
0:2 1:3 3:1题目来源:PAT乙级1021
作者:CHEN, Yue
单位:浙江大学
问题解决:
解题思想
为不超过 1000 位的正整数,显然不能用单个变量来存
的值,可用字符数组存入
的每一位;输入时遇到换行即输入结束;设置一个整型数组coun[10]来统计各位数字出现的次数;个数为0个的数字不输出。
代码示例(C/C++)
小提示:请将以下代码保存为.cpp格式(C++程序)左右滑动代码可查看全部内容
#include <cstdio>
#define MAXN 1001
using namespace std;
int main()
{
char num[MAXN];//用字符数组存入输入的大数
int i = 0;
num[i] = getchar();
while(num[i] != '\n'){//遇到换行即输入结束
i++;
num[i] = getchar();
}
i = 0;
int coun[10] = {0};//统计数组
while(num[i] != '\n'){
int n = num[i] - '0';//字符转化为数字
coun[n]++;
i++;
}
for(i = 0; i < 10; i++){
if(coun[i] != 0){//个数为0个的数字不输出
printf("%d:%d\n",i,coun[i]);
}
}
return 0;
}

微信号:aiyoutao76