服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|编程技术|正则表达式|

服务器之家 - 编程语言 - PHP教程 - php实现插入排序

php实现插入排序

2020-09-15 15:57PHP教程网 PHP教程

本文给大家分享的是使用php实现插入排序的方法,十分的简单实用,有需要的小伙伴可以参考下。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
<?php
/**
 * 插入排序
 * @param Array $a 无序集合
 * @return Array 有序集合
 */
function insertSort($a) {
  $temp;
  $i;
  $j;
  $size_a = count($a);
  # 从第二个元素开始
  for ($i = 1; $i < $size_a; $i++) {     
    if ($a[$i] < $a[$i-1]) {    
      $j = $i; # 保存当前元素的位置
      $temp = $a[$i]; # 当前元素的值 
 
      # 比较左边的元素,如果找到比自己更小的,向右移动元素,否则插入元素到当前位置
      while($j>0 && $temp<$a[$j-1]) {
        $a[$j] = $a[$j-1];
        $j--;
      }
       
      # 插入元素
      $a[$j] = $temp;
    }
  }
  return $a;
}
/**
 * 获取随机数
 * @param Integer $size 数量
 * @return Integer
 */
function randomNumber($size = 10) {
  $rand = array();
  srand(time(NULL));
  for ($i = 0; $i < $size; $i++) {
    array_push($rand, mt_rand(0,1000));  
  }
  return $rand;
}
 
$a = randomNumber();
echo sprintf("Unsorted list %s\n", implode(" ", $a));
echo sprintf("Sorted list %s\n", implode(" ", insertSort($a)));

以上就是本文所述的全部内容了,希望大家能够喜欢。

延伸 · 阅读

精彩推荐
  • PHP教程深入PHP运行环境配置的详解

    深入PHP运行环境配置的详解

    本篇文章是对PHP运行环境配置进行了详细的分析介绍,需要的朋友参考下 ...

    PHP教程网3632020-04-02
  • PHP教程学习php中的正则表达式

    学习php中的正则表达式

    简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具。我们可以在几乎所有的基于UNIX系统的工具中找到ta的身影。此外,象JavaScript这种客...

    PHP教程网3322020-07-22
  • PHP教程php读取mysql的简单实例

    php读取mysql的简单实例

    读取数据库我们需要利用php中的函数连接数据库然后再利用sql查询 表中的数据再遍历出来即可了,下面我们来看一个简单读取mysql实例 ...

    PHP教程网1512020-06-05
  • PHP教程使用PHPRPC实现Ajax安全登录

    使用PHPRPC实现Ajax安全登录

    PHPRPC 是一个轻型的、安全的、跨网际的、跨语言的、跨平台的、跨环境的、跨域的、支持复杂对象传输的、支持引用参数传递的、支持内容输出重定向的、...

    PHP教程网4782019-12-15
  • PHP教程php+Ajax无刷新验证用户名操作实例详解

    php+Ajax无刷新验证用户名操作实例详解

    这篇文章主要介绍了php+Ajax无刷新验证用户名操作,简单介绍了ajax的原理并结合实例形式分析了php结合ajax无刷新验证用户名相关操作技巧,需要的朋友可以参...

    致Great2362019-06-06
  • PHP教程PHP基于面向对象封装的分页类示例

    PHP基于面向对象封装的分页类示例

    这篇文章主要介绍了PHP基于面向对象封装的分页类,结合实例形式分析了php分页类针对页码判断、显示等操作的封装及分页类使用相关操作技巧,需要的朋友...

    小菜鸟有大梦想1852019-05-31
  • PHP教程PHP 5.5 创建和验证哈希最简单的方法详解

    PHP 5.5 创建和验证哈希最简单的方法详解

    最近 PHP 5.5.0 发布了,并带来了一份完整的全新特性与函数的列表。全新API之一就是Password Hashing API.它包含4个函数:password_get_info(), password_hash(), password_n...

    PHP教程网3542020-05-27
  • PHP教程php_screw 1.5:php加密: 安装与使用详解

    php_screw 1.5:php加密: 安装与使用详解

    本篇文章是对php_screw 1.5:php加密: 安装与使用进行了详细的分析介绍,需要的朋友参考下 ...

    PHP教程网1502020-04-21