温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何在php项目中实现一个希尔排序算法

发布时间:2020-12-31 16:07:39 来源:亿速云 阅读:198 作者:Leah 栏目:开发技术

如何在php项目中实现一个希尔排序算法?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

希尔排序(shell sort):希尔排序是基于插入排序的,区别在于插入排序是相邻的一个个比较(类似于希尔中h=1的情形),而希尔排序是距离h的比较和替换。

希尔排序中一个常数因子n,原数组被分成各个小组,每个小组由h个元素组成,很可能会有多余的元素。当然每次循环的时候,h也是递减的(h=h/n)。第一次循环就是从下标为h开始。希尔排序的一个思想就是,分成小组去排序。

理解这些算法,最好是有个图示。就先来代码吧。

<?php /**  * 希尔排序  */ function shell_sort(array $arr){   // 将$arr按升序排列   $len = count($arr);   $f = 3;// 定义因子   $h = 1;// 最小为1   while ($h < $len/$f){     $h = $f*$h + 1; // 1, 4, 13, 40, 121, 364, 1093, ...   }   while ($h >= 1){ // 将数组变为h有序     for ($i = $h; $i < $len; $i++){ // 将a[i]插入到a[i-h], a[i-2*h], a[i-3*h]... 之中 (算法的关键       for ($j = $i; $j >= $h; $j -= $h){         if ($arr[$j] < $arr[$j-$h]){           $temp = $arr[$j];           $arr[$j] = $arr[$j-$h];           $arr[$j-$h] = $temp;         }         //print_r($arr);echo '<br/>'; // 打开这行注释,可以看到每一步被替换的情形       }     }     $h = intval($h/$f);   }   return $arr; } $arr = array(14, 9, 1, 4, 6, -3, 2, 99, 13, 20, 17, 15, 3); $shell = shell_sort($arr); echo '<pre>'; print_r($shell); /** * Array ( [0] => -3 [1] => 1 [2] => 2 [3] => 3 [4] => 4 [5] => 6 [6] => 9 [7] => 13 [8] => 14 [9] => 15 [10] => 17 [11] => 20 [12] => 99 ) ) * */

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI