cari
Rumahpembangunan bahagian belakangtutorial phpphp冒泡,选择,插入和快速排序法详解
php冒泡,选择,插入和快速排序法详解Mar 13, 2018 am 10:41 AM
phpcepatmenyusun

=分别用 冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中 的值按照从小到的顺序进行排序。 

$arr(1,43,54,62,21,66,32,78,36,76,39);

1. 冒泡排序法 
 *     思路分析:法如其名,就是像冒泡一样,每次从数组当中 冒一个最大的数出来。 

 *     比如:2,4,1    // 第一次 冒出的泡是4 
 *                2,1,4   // 第二次 冒出的泡是 2 
 *                1,2,4   // 最后就变成这样
$arr=array(1,43,54,62,21,66,32,78,36,76,39);    
function getpao($arr)  
{    
  $len=count($arr);  
  //设置一个空数组 用来接收冒出来的泡  
  //该层循环控制 需要冒泡的轮数  
  for($i=1;$i<$len;$i++)  
  { //该层循环用来控制每轮 冒出一个数 需要比较的次数  
    for($k=0;$k<$len-$i;$k++)  
    {  
       if($arr[$k]>$arr[$k+1])  
        {  
            $tmp=$arr[$k+1];  
            $arr[$k+1]=$arr[$k];  
            $arr[$k]=$tmp;  
        }  
    }  
  }  
  return $arr;  
}
  1. 2. 选择排序法: 



  2. 选择排序法思路: 每次选择一个相应的元素,然后将其放到指定的位置



  1. function select_sort($arr) {  
    //实现思路 双重循环完成,外层控制轮数,当前的最小值。内层 控制的比较次数  
        //$i 当前最小值的位置, 需要参与比较的元素  
        for($i=0; $len=count($arr); $i<$len-1; $i++) {  
            //先假设最小的值的位置  
            $p = $i;  
            //$j 当前都需要和哪些元素比较,$i 后边的。  
            for($j=$i+1; $j<$len; $j++) {  
                //$arr[$p] 是 当前已知的最小值  
                if($arr[$p] > $arr[$j]) {  
         //比较,发现更小的,记录下最小值的位置;并且在下次比较时,  
     // 应该采用已知的最小值进行比较。  
                    $p = $j;  
                }  
            }  
            //已经确定了当前的最小值的位置,保存到$p中。  
     //如果发现 最小值的位置与当前假设的位置$i不同,则位置互换即可  
            if($p != $i) {  
                $tmp = $arr[$p];  
                $arr[$p] = $arr[$i];  
                $arr[$i] = $tmp;  
            }  
        }  
        //返回最终结果  
        return $arr;  
    }


3.插入排序法 

插入排序法思路:将要排序的元素插入到已经 假定排序号的数组的指定位置。

  1. function insert_sort($arr) {  
        //区分 哪部分是已经排序好的  
        //哪部分是没有排序的  
        //找到其中一个需要排序的元素  
        //这个元素 就是从第二个元素开始,到最后一个元素都是这个需要排序的元素  
        //利用循环就可以标志出来  
        //i循环控制 每次需要插入的元素,一旦需要插入的元素控制好了,  
        //间接已经将数组分成了2部分,下标小于当前的(左边的),是排序好的序列  
        for($i=1, $len=count($arr); $i<$len; $i++) {  
            //获得当前需要比较的元素值。  
            $tmp = $arr[$i];  
            //内层循环控制 比较 并 插入  
            for($j=$i-1;$j>=0;$j--) {  
       //$arr[$i];//需要插入的元素; $arr[$j];//需要比较的元素  
                if($tmp < $arr[$j]) {  
                    //发现插入的元素要小,交换位置  
                    //将后边的元素与前面的元素互换  
                    $arr[$j+1] = $arr[$j];  
                    //将前面的数设置为 当前需要交换的数  
                    $arr[$j] = $tmp;  
                } else {  
                    //如果碰到不需要移动的元素  
               //由于是已经排序好是数组,则前面的就不需要再次比较了。  
                    break;  
                }  
            }  
        }  
        //将这个元素 插入到已经排序好的序列内。  
        //返回  
        return $arr;  
    }


4.快速排序法  

  1. function quick_sort($arr) {  
        //先判断是否需要继续进行  
        $length = count($arr);  
        if($length <= 1) {  
            return $arr;  
        }  
        //如果没有返回,说明数组内的元素个数 多余1个,需要排序  
        //选择一个标尺  
        //选择第一个元素  
        $base_num = $arr[0];  
        //遍历 除了标尺外的所有元素,按照大小关系放入两个数组内  
        //初始化两个数组  
        $left_array = array();//小于标尺的  
        $right_array = array();//大于标尺的  
        for($i=1; $i<$length; $i++) {  
            if($base_num > $arr[$i]) {  
                //放入左边数组  
                $left_array[] = $arr[$i];  
            } else {  
                //放入右边  
                $right_array[] = $arr[$i];  
            }  
        }  
        //再分别对 左边 和 右边的数组进行相同的排序处理方式  
        //递归调用这个函数,并记录结果  
        $left_array = quick_sort($left_array);  
        $right_array = quick_sort($right_array);  
        //合并左边 标尺 右边  
        return array_merge($left_array, array($base_num), $right_array);  
    }

Atas ialah kandungan terperinci php冒泡,选择,插入和快速排序法详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php怎么读取字符串后几个字符php怎么读取字符串后几个字符Apr 22, 2022 pm 08:31 PM

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace("&nbsp;","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么查找字符串是第几位php怎么查找字符串是第几位Apr 22, 2022 pm 06:48 PM

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),