为了账号安全,请及时绑定邮箱和手机立即绑定

【金秋打卡】第6天+C语言入门

  • 文章标题:【金秋打卡】第6天+C语言入门

  • 第一模块: 学习课程名称:C语言入门;章节名称(序号):6-5数组应用(一);讲师姓名:自学,文字版本

  • 第二模块: 课程内容(内容概述):

    排序的方法呢有很多,这里小编给大家介绍一种比较经典且比较容易掌握的排序方法:冒泡排序

    以升序排序为例冒泡排序的思想:相邻元素两两比较,将较大的数字放在后面,直到将所有数字全部排序。就像小学排队时按大小个排一样,将一个同学拉出来和后面的比比,如果高就放后面,一直把队伍排好。

    班级成绩中,老师把前十名的挑出来了,用冒泡排序把分数排了一下

    运行结果为

  • 第三模块: 最终的解决思路:

#include <stdio.h>

int main()

{

    double arr[]={1.78, 1.77, 1.82, 1.79, 1.85, 1.75, 1.86, 1.77, 1.81, 1.80};

    int i,j;

    printf("\n************排队前*************\n");

    for(i=0;i<10;i++)

    {

        if(i != 9)   

            printf("%.2f, ", arr[i]);  //%.2f表示小数点后精确到两位

        else

            printf("%.2f", arr[i]);    //%.2f表示小数点后精确到两位

    }

    for(i=8; i>=0; i--)

    {

        for(j=0;j<=i;j++)

        {

            if( arr[j]>arr[j+1] )      //当前面的数比后面的数大时

            {

                double temp;    //定义临时变量temp

                temp = arr[j];     //将前面的数赋值给temp

                arr[j]=arr[j+1];             //前后之数颠倒位置

                arr[j+1]=temp;              //将较大的数放在后面    

            }                 

        }                

    }

    printf("\n************排队后*************\n");

    for(i=0;i<10;i++)

    {

        if(i != 9)   

            printf("%.2f, ", arr[i]);  //%.2f表示小数点后精确到两位     

        else

            printf("%.2f", arr[i]);    //%.2f表示小数点后精确到两位

    }

    return 0;    

}

第一次写并没有写对,发现自己很多次在定义时忘记“;”,下次一定记住!

https://img2.sycdn.imooc.com/635c94d50001fef415920877.jpg

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消