欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

php快速排序的算法

程序员文章站 2022-06-14 21:27:10
...
  1. function qsort(&$arr)
  2. {
  3. _quick_sort($arr, 0, count($arr) - 1);
  4. }
  5. /**
  6. * 采用递归算法的快速排序。
  7. *
  8. * @param array $arr 要排序的数组
  9. * @param int $low 最低的排序子段
  10. * @param int $high 最高的排序字段
  11. */
  12. function _quick_sort(&$arr, $low, $high)
  13. {
  14. $low_data = $arr[$low];
  15. $prev_low = $low;
  16. $prev_high = $high;
  17. while ($low {
  18. while ($arr[$high] >= $low_data && $low $high--;
  19. }
  20. if ($low $arr[$low] = $arr[$high];
  21. $low++;
  22. }
  23. while ($arr[$low] $low++;
  24. }
  25. if ($low $arr[$high] = $arr[$low];
  26. $high--;
  27. }
  28. }
  29. $arr[$low] = $low_data;
  30. if ($prev_low _quick_sort($arr, $prev_low, $low);
  31. }
  32. if ($low + 1 _quick_sort($arr, $low + 1, $prev_high);
  33. }
  34. }
  35. function quick_sort(&$arr)
  36. {
  37. $stack = array();
  38. array_push($stack, 0);
  39. array_push($stack, count($arr) -1);
  40. while (!empty($stack)) {
  41. $high = array_pop($stack);
  42. $low = array_pop($stack);
  43. $low_data = $arr[$low];
  44. $prev_low = $low;
  45. $prev_high = $high;
  46. while ($low {
  47. while ($arr[$high] >= $low_data && $low $high--;
  48. }
  49. if ($low $arr[$low] = $arr[$high];
  50. $low++;
  51. }
  52. while ($arr[$low] $low++;
  53. }
  54. if ($low $arr[$high] = $arr[$low];
  55. $high--;
  56. }
  57. }
  58. $arr[$low] = $low_data;
  59. if ($prev_low array_push($stack, $prev_low);
  60. array_push($stack, $low);
  61. }
  62. if ($low + 1 array_push($stack, $low + 1);
  63. array_push($stack, $prev_high);
  64. }
  65. }
  66. }
复制代码

php