PHP常见算法【冒泡排序,快速排序,插入排序,取舍排序,二分法查找,.】
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了PHP常见算法【冒泡排序,快速排序,插入排序,取舍排序,二分法查找,.】,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2284字,纯文字阅读大概需要4分钟。
内容图文
![PHP常见算法【冒泡排序,快速排序,插入排序,取舍排序,二分法查找,.】](/upload/InfoBanner/zyjiaocheng/216/b5d93cbd46804db3a01f02dee5d470e0.jpg)
// 冒泡排序 function bubblesort($arr) { for($i=0,$j=count($arr); $i<$j; $i++) { for($k=$j-1; $k>$i; $k--) { if ($arr[$k] < $arr[$k-1]) list($arr[$k-1], $arr[$k]) = array($arr[$k], $arr[$k-1]); } } return $arr; } $arr = array(1,4,14,3,56,23,435,2,234,2,33,23,123); print_r(bubblesort($arr));
// 快速排序 function quicksort($arr) { if(($count = count($arr)) <= 1 ) return $arr; $base = $arr[0]; $left = $right = array(); for($i=1; $i<$count; $i++) { if($arr[$i] <= $base) $left[] = $arr[$i]; else $right[] = $arr[$i]; } $left = quicksort($left); $right = quicksort($right); return array_merge($left, array($base), $right); } echo join(',', quicksort(array(1,3,23,5,234,65,6)));?
// 插入排序 function insertsort($arr) { for($i=1, $j=count($arr); $i<$j; $i++) { $k = $i; while($k > 0 && $arr[$k-1] > $arr[$k]) { list($arr[$k], $arr[$k-1]) = array($arr[$k-1], $arr[$k]); $k--; } } return $arr; } $array=array(10,8,7,5,1,2,3,4); print_r(insertsort($array));
// 选择排序, (非递归) function selectsort($arr) { for($i=0, $j=count($arr); $i<=$j; $i++) { $min = $i; $temp = $arr[$i]; for($k=$i+1; $k<$j; $k++) { if($temp > $arr[$k]) { $min = $k; $temp = $arr[$k]; } } if($min != $i) list($arr[$min], $arr[$i]) = array($arr[$i], $arr[$min]); } return $arr; } $arr = array(9,3,11,23,90,99,12,34,22,87,32); print_r(selectsort($arr));
// 选择排序(递归实现) function selectsort2($arr, $start = 0) { if(($count = count($arr)) == $start + 1) return $arr; $new = array(); $min = $arr[$start]; $min_index = $start; for($i=$start+1; $i<$count-1; $i++) { if($arr[$i] < $min) { $min = $arr[$i]; $min_index = $i; } } if($arr[$start] != $min) list($arr[$start], $arr[$min_index]) = array($arr[$min_index], $arr[$start]); return selectsort($arr, $start + 1); } $arr = array(9,3,11,23,90,99,12,34,22,87,32); print_r(selectsort($arr));?
<?php // 二分法查找 function binarysearch($arr, $value, $start = 0, $end = NULL) { if($end == NULL) $end = count($arr) - 1; $index = floor(($start+$end)/2); $base = $arr[$index]; if($value < $base) return binarysearch($arr, $value, $start, $index-1); else if($value > $base) return binarysearch($arr, $value, $index+1, $end); else return $index; } $arr = array(1, 3, 5, 6, 7, 8, 10, 12, 14, 16, 18, 20); $value = 8; echo binarysearch($arr, $value);?
待续...
内容总结
以上是互联网集市为您收集整理的PHP常见算法【冒泡排序,快速排序,插入排序,取舍排序,二分法查找,.】全部内容,希望文章能够帮你解决PHP常见算法【冒泡排序,快速排序,插入排序,取舍排序,二分法查找,.】所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。