只用两个for循环同时实现升降序输出

本文介绍了一个自定义的排序算法实现,该算法可以根据标志位选择升序或降序排列整数数组,并提供了主函数中的调用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是我自己写的,大家指点一下,或者自己下一下也行。交流交流

void Sort(int *a, int nSelect,int flag)
{
          int nRaw;
         int nList;
          int nTemp;
         for(nRaw = 0; nRaw < 10; nRaw++){
              for(nList = nRaw; nList < 10; nList++){
                     if(a[nRaw] > a[nList] ? nSelect : flag){  /* switch the two number */

                              nTemp = a[nRaw];
                              a[nRaw] = a[nList];
                              a[nList] = nTemp;
                    }
    
             }
         }

}

 

主函数中调用分别为:

        

          printf("ascending: ");
         Sort(num, 1, 0);
         for(i = 0; i < 10; i++){ /* output arrar in ascending order */
  
         printf("%d ",num[i]); /*output your Array */
         }
         printf("\n\n");


        printf("descending: ");
        Sort(num, 0, 1);
        for(i = 0; i < 10; i++){ /* output arrar in descending order */
  
       printf("%d ",num[i]); /*output your Array */
         }
       printf("\n\n");

 

大家还有没有更好的实现方法?

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值