PHP数组冒泡排序新手如何理解

长话短说,直击重点!

上代码:

    $pai = array(0,-98,10,40,-20,1,200,-300,58);
    $temp=0;
    for ($i=0;$i<count($pai)-1;$i++) {
        for ($j=0;$j<count($pai)-1-$i;$j++) {
            if ($pai[$j] > $pai[$j+1]) {
                $temp = $pai[$j+1];
                $pai[$j+1] = $pai[$j];
                $pai[$j] = $temp;
            }
        }
    }

思想: 前后两个比较,把大的值往后放

代码两层循环意思:

1.数组元素个数减一: 因为前后两个比较,如果是最后一个的话没有比较对象了,固然是不用比了

2.第二层循环减去$i的意思:每次比较完了就会有个结果在最后面,下次比较的时候就不需要比较这个值了

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值