0-10中五个数排序(使用一维数组)

题目:

      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间的也能满足,只需要把数组扩大就行了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值