我对这道题的基本思路是:通过字符串输出这些数,然后进行遍历,使用新建的数组对重复出现的数字进行保存,最后输出值数组中值不为零的数。
最关键的是:利用下标来保存重复的数并使下标的值自增。
这个比较繁琐,还会有更简练的,望各位大佬指出不足。
代码如下:
#include <stdio.h>
int main(void)
{
char num[1024];
int record[10] = {0};
int i = 0;
if(scanf("%s", num));
for (i = 0; num[i]; i++)
{
switch (num[i] - '0')
{
case 0: record[num[i] - '0']++; break;
case 1: record[num[i] - '0']++; break;
case 2: record[num[i] - '0']++; break;
case 3: record[num[i] - '0']++; break;
case 4: record[num[i] - '0']++; break;
case 5: record[num[i] - '0']++; break;
case 6: record[num[i] - '0']++; break;
case 7: record[num[i] - '0']++; break;
case 8: record[num[i] - '0']++; break;
case 9: record[num[i] - '0']++; break;
}
}
for (i = 0; i<10; i++)
{
if (record[i] != 0)
{
printf("%d:%d\n", i,record[i]);
}
}
return 0;
}