zoukankan      html  css  js  c++  java
  • 数据结构与算法之PHP排序算法(插入排序)

    一、基本思想
    插入排序算法是每一步将一个待排序的数据插入到前面已经排好序的有序序列中,直到所有元素插入完毕为止。
     
    二、算法过程
    1)将第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列;
    2)从头到尾依次扫描未排序序列,将扫描到的每个元素插入有序序列的适当位置(如果待插入的元素与有序序列中的某个元素相等,则将待插入元素插入到相等元素的后面,这样的插入方式,排序是稳定的)。
     
    三、算法图解
     
    四、PHP代码实现
    function insertSort($arr) {
        $len = count($arr);
        for ($i = 1; $i < $len; $i++) {
            $temp = $arr[$i];
            for ($j = $i - 1; $j >= 0; $j--) {
                if ($temp < $arr[$j]) {
                    $arr[$j + 1] = $arr[$j];
                    $arr[$j] = $temp;
                } else {
                    break;
                }
            }
        }
        return $arr;
    }
     
    五、效率分析
    1、时间复杂度:O(n²)
    最好的情况:待排序记录按关键字从小到大排列(正序),需要比较n-1次,不需要交换元素,时间复杂度为O(n);
    最坏的情况:待排序记录按关键字从大到小排列(逆序),时间复杂度为O(n²)。
    2、空间复杂度:O(1),是稳定排序。
  • 相关阅读:
    算法导论--2.2分析算法
    C++对象模型
    算法导论--插入排序
    记一次Chrome冒充QQ浏览器领取奖励之行
    eclipse做界面开发
    eclipse jad 反编译 插件安装
    eclipse下web开发中缓存问题
    eclipse缓存问题
    No more “busy and acquire with NOWAIT”
    ora-00054:resource busy and acquire with nowait specified解决方法
  • 原文地址:https://www.cnblogs.com/sunshineliulu/p/8441237.html
Copyright © 2011-2022 走看看