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),是稳定排序。
  • 相关阅读:
    向量的基本运算
    tar 命令小解
    写一个块设备驱动11,12
    写一个块设备驱动9,10
    写一个块设备驱动7,8
    写一个块设备驱动5,6
    写一个块设备驱动1,2
    Linux驱动开发庖丁解牛系列
    Linux设备驱动程序(第三版)
    嵌入式系统移植基础三部曲 段彦青
  • 原文地址:https://www.cnblogs.com/sunshineliulu/p/8441237.html
Copyright © 2011-2022 走看看