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),是稳定排序。
  • 相关阅读:
    Tomcat线程参数
    CDH平台规划注意事项
    python 不同数据类型的序列化
    Python 中__new__方法详解及使用
    线程生命周期
    如何在JAVA中每隔一段时间执行一段程序
    手动开启是事务提交回滚
    MySQL数据类型转换函数CAST与CONVERT的用法
    mybatis插入是返回主键id
    解决dubbo注册zookepper服务IP乱入问题的三种方式
  • 原文地址:https://www.cnblogs.com/sunshineliulu/p/8441237.html
Copyright © 2011-2022 走看看