MATLAB每日一题-1-起泡法排序

前言:

因浏览python每日一题的人有很多,大家对题颇为关注,所以在这里出一个系列专栏关于matlab的习题专集,也为期末复习打下基础,希望能够在这里和大家共同学习共同进步。

还是一个小白,边学边写,接触时间没有很长,如果文章有任何错误,欢迎大家指正。

如果喜欢我的文章还请大家不吝动手给我点赞收藏关注哦,留下你来过的足迹,让我眼熟你。

第一题    起泡法排序 

要求:

1.用起泡法对10个数由小到大排序

2.有能力的同学可以试试输入任意数字由小到大排序

提示:

1.相邻两个数比较,将小的调到前头

2.for循环嵌套if循环

1)此代码已经规定a内的数字,以此代码是让同学理解起泡法运行原理,在命令行窗口输入a,排序后的数字将会显示出来

a = [1 5 2 7 11 3 4 9 18 37];
for i = 1:10
    for n = 1:10-i
    if a(n) > a(n+1)
        y = a(n);
        a(n)=a(n+1);
        a(n+1)=y ;
    end
    end
end

结果如下所示: 

a =

     1     2     3     4     5     7     9    11    18    37

注意:也可以在脚本M文件中不加;号,此时直接运行脚本M文件即可得到结果。 

2)此代码为任意输入任意个数字起泡排序的代码,大家可以和上面的对比一下,会发现原理都是一样的。

function a=qipao(a)
for i = 1:length(a)
    for n = 1:length(a)-i
    if a(n) > a(n+1)
        y = a(n);
        a(n)=a(n+1);
        a(n+1)=y ;
    end
    end
end

在命令行窗口输入如下代码,结果如下所示: 

>> a = [7 5 6 4 8 79 45]

a =

     7     5     6     4     8    79    45

>> qipao(a)

ans =

     4     5     6     7     8    45    79
  • 4
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qqgg77

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值