题目:
0-10中五个数排序
输入:
0-10中的五个数
输出:
按从小到大排列的五个数
样例输入:
4 5 2 9 5
样例输出:
2 4 5 5 9
代码如下:
#include <stdio.h>
int main()
{
int a[11],i,j,t;
for(i=0;i<=10;i++)
a[i]=0; //初始化为0
for(i=1;i<=5;i++) //循环读入5个数
{
scanf("%d",&t); //把每一个数读到变量t中
a[t]++; //进行计数
}
for(i=0;i<=10;i++) //依次判断a[0]~a[10]
for(j=1;j<=a[i];j++) //出现了几次就打印几次
printf("%d ",i);
getchar();
getchar();
//这里的getchar();用来暂停程序,以便查看程序输出的内容
//也可以用system("pause");等来代替
return 0;
}
思想:
首先我们申请一个大小为 11 的数组 int a[11],即从 a[0]~a[10],且都初始化为 0。
下面开始处理每一个人的分数,第一个人的分数是 4 分,我们就将相对应的 a[4]的值在
原来的基础增加 1,即将 a[4]的值从 0 改为 1,表示 4 分出现过了一次,
第二个人的分数是 5 分,我们就把相对应的 a[5]的值在原来的基础上增加 1,即将 a[5]
的值从 0 改为 1,表示 5 分出现过了一次。
注意啦!
第五个人的分数也是 5 分,所以 a[5]的值需要在此基础上再增加 1,即将 a[5]
的值从 1 改为 2,表示 5 分出现过了两次。
你发现没有,a[0]~a[10]中的数值其实就是 0 分到 10 分每个分数出现的次数。接下来,
我们只需要将出现过的分数打印出来就可以了,出现几次就打印几次,具体如下。
a[0]为 0,表示“0”没有出现过,不打印。
a[1]为 0,表示“1”没有出现过,不打印。
a[2]为 1,表示“2”出现过 1 次,打印 2。
a[3]为 0,表示“3”没有出现过,不打印。
a[4]为 1,表示“4”出现过 1 次,打印4。
a[5]为 2,表示“5”出现过 2 次,打印 5 5。
a[6]为 0,表示“6”没有出现过,不打印。
a[7]为 0,表示“7”没有出现过,不打印。
a[8]为 0,表示“8”没有出现过,不打印 。
a[9]为 1,表示“9”出现过 1 次,打印9。
a[10]为 0,表示“10”没有出现过,不打印。
最终屏幕输出“2 4 5 5 9”,
当然
0-1000间的也能满足,只需要把数组扩大就行了。