C语言练习题(6)

简单选择排序法(数组篇)

(全部代码在最后)

目的如下:

随便给出几个数{32,51,88,40,49},要求这一组数按照升序(从小到大)排列或降序(从大到小)排列。

首先我们定义一些需要用到的变量:

 len的作用是计算出数组的长度。

接下来进入第一步:

第二步:

这里可能有些小白会看不懂,粗略讲解一下。

变量i是在数组内的,代表数组的位数。如题所示的一个存放五个整数的数组,i<len-1代表for循环只能循环到5-1=4次,也就是它arr[i]只能读取第1、2、3、4位,而下方的arr[j]可以读取第2、3、4、5位。

第三步:

 

 运行结果如下:

 

 全部代码奉上:

#include <stdio.h>
int main(){
    int arr[5];
    int i,j,tmp;
    int len;
    len = sizeof(arr)/sizeof(arr[0]);
    
    //1.初始化:
    printf("请依次输入5个数,它们将自动组成一个数组:\n");
    scanf("%d%d%d%d%d",&arr[0],&arr[1],&arr[2],&arr[3],&arr[4]);
    
    //2.判断大小并排序:
    for(i=0;i<len-1;i++){
        for(j=i+1;j<len;j++){
        if(arr[i] > arr[j]){
            tmp = arr[i];
            arr[i] = arr[j];
            arr[j] = tmp;
            }
        }
    }
    
    //3.输出结果
    for(i=0;i<len;i++){
        printf("%d ",arr[i]);
    }
    
    
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值