PTA 1021 个位数统计(C语言)

我对这道题的基本思路是:通过字符串输出这些数,然后进行遍历,使用新建的数组对重复出现的数字进行保存,最后输出值数组中值不为零的数。

最关键的是:利用下标来保存重复的数并使下标的值自增。

这个比较繁琐,还会有更简练的,望各位大佬指出不足。

代码如下:
#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;
}

猜你喜欢

转载自blog.csdn.net/despicto/article/details/83959048
今日推荐