PHP冒泡排序算法
web PHP 2019-04-24 1898 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

6456335 2613 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (254)
Mysql (58)
DedeCms (33)
jQuery (67)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)
冒泡排序:http://www.taotaoit.com/article/details/767.html
快速排序:http://www.taotaoit.com/article/details/654.html
插入排序:http://www.taotaoit.com/article/details/766.html

冒泡排序算法的原理如下:
1,比较相邻的元素。如果第一个比第二个大,就交换他们两个。
2,对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
3,针对所有的元素重复以上的步骤,除了最后一个。
4,持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

<?php
/**
 * 冒泡排序
 * @param array $arr [待排序数组]
 * @return array [已排序好的数组]
 */
function bubbleSorting(array $arr) {
    $length = count($arr);
    for($i = 0; $i < $length - 1; $i++) {
        $mark = 1; //做一个标记,如果在本次排序过程中,没有出现交换的情况,说明排序已经有序,可以直接跳出循环,减少不必要的比较
        for($j = 0; $j < ($length - $i - 1); $j++) {
            if ($arr[$j] > $arr[$j + 1]) {
                $mark = 0; //出现了交换情况,则将标记改为0
                $temp = $arr[$j];
                $arr[$j] = $arr[$j + 1];
                $arr[$j + 1] = $temp;
            } 
        } 
        if ($mark) { // $mark值未出现变化,排序已经有序,直接返回结果即可
            return $arr;
        } 
    } 
    return $arr;
} 
$arr = array('5', '2', '0', '1', '3', '1', '4');
print_r(bubbleSorting($arr));
// Array ( [0] => 0 [1] => 1 [2] => 1 [3] => 2 [4] => 3 [5] => 4 [6] => 5 )
?>
时间复杂度:O(n2)
在最好情况下(正序),元素的交换次数为0,比较次数为n - 1
在最坏情况下(正序),元素的交换次数为n(n-1)/2,比较次数为n(n-1)/2
空间复杂度:O(1)
只需要一个辅助单元进行交换
适用情况:
元素数目少,或者元素的初始序列基本有序


版权声明:本篇文章来源于网络。 来源链接

相关推荐
php实现ZIP压缩文件解压缩,中文乱码解决方法(重要)
PHP | 2019-04-30 5634
直接上代码,具体代码里面都有注释。直接中文压缩文件解压到中文文件夹。 <?php // 需开启配置 php_zip.dll // phpinfo(); header("Content-type:text/html;charset=utf-8"); /* * $filename 被解压文件名 * $path 解压...
openssl_private_decrypt解密失败
PHP | 2019-01-16 5607
复制别人的解密程序,原程序可以解密,复制过来就不可以 一步步尝试发现,秘钥换行符有区别, 原秘钥有换行符,复制过来不知道什么时候把换行符清空了,成了一行字符串了。
评论:0条
评论加载中...
发表评论