当前位置:Gxlcms > PHP教程 > QuickSortIn-placeImplementation,quicksort_PHP教程

QuickSortIn-placeImplementation,quicksort_PHP教程

时间:2021-07-01 10:21:17 帮助过:24人阅读

Quick Sort In-place Implementation,quicksort


在线运行PHP http://www.compileonline.com/execute_php_online.php

  1. <span> 1</span> <!--?<span-->php
  2. <span> 2</span> <span>function</span> swap( &<span>$a</span>, &<span>$b</span><span> )
  3. </span><span> 3</span> <span>{
  4. </span><span> 4</span> <span>$c</span> = <span>$a</span><span>;
  5. </span><span> 5</span> <span>$a</span> = <span>$b</span><span>;
  6. </span><span> 6</span> <span>$b</span> = <span>$c</span><span>;
  7. </span><span> 7</span> <span>}
  8. </span><span> 8</span>
  9. <span> 9</span> <span>/*</span><span>*
  10. </span><span>10</span> <span>* quick sort
  11. </span><span>11</span> <span>* ascend
  12. </span><span>12</span> <span>* in-place
  13. </span><span>13</span> <span>*/</span>
  14. <span>14</span> <span>function</span> quick_sort( &<span>$a</span><span> )
  15. </span><span>15</span> <span>{
  16. </span><span>16</span> <span>$s</span> = <span>count</span>( <span>$a</span> ); <span>//</span><span> size of a</span>
  17. <span>17</span> <span>if</span> ( <span>$s</span> < 2 ) <span>return</span><span>;
  18. </span><span>18</span> <span>$i</span> = 0; <span>//</span><span> index of pivot, for tracking pivot</span>
  19. <span>19</span> <span>$pivot</span> = <span>$a</span>[<span>$i</span><span>];
  20. </span><span>20</span> <span>$l</span> = 0; <span>//</span><span> swap listener, if listens no swap, sort fini
  21. </span><span>21</span>
  22. <span>22</span> <span> // swap those smaller than pivot to the left</span>
  23. <span>23</span> <span>for</span> ( <span>$m</span> = 0; <span>$m</span> < <span>$s</span>; <span>$m</span>++<span> )
  24. </span><span>24</span> <span> {
  25. </span><span>25</span> <span>if</span> ( <span>$a</span>[<span>$m</span>] < <span>$a</span>[<span>$i</span><span>] )
  26. </span><span>26</span> <span> {
  27. </span><span>27</span> swap( <span>$a</span>[<span>$m</span>], <span>$a</span>[<span>$i</span><span>] );
  28. </span><span>28</span> <span>$i</span> = <span>$m</span><span>;
  29. </span><span>29</span> <span>$l</span>++<span>;
  30. </span><span>30</span> <span> }
  31. </span><span>31</span> <span> }
  32. </span><span>32</span>
  33. <span>33</span> <span>//</span><span> swap those larger than pivot to the right</span>
  34. <span>34</span> <span>for</span> ( <span>$n</span> = 0; <span>$n</span> < <span>$i</span>; <span>$n</span>++<span>)
  35. </span><span>35</span> <span> {
  36. </span><span>36</span> <span>if</span> ( <span>$a</span>[<span>$n</span>] > <span>$a</span>[<span>$i</span><span>] )
  37. </span><span>37</span> <span> {
  38. </span><span>38</span> swap( <span>$a</span>[<span>$n</span>], <span>$a</span>[<span>$i</span><span>] );
  39. </span><span>39</span> <span>$i</span> = <span>$n</span><span>;
  40. </span><span>40</span> <span>$l</span>++<span>;
  41. </span><span>41</span> <span> }
  42. </span><span>42</span> <span> }
  43. </span><span>43</span>
  44. <span>44</span> <span>if</span> ( <span>$l</span> == 0 ) <span>return</span><span>;
  45. </span><span>45</span> <span>else</span> <span>$l</span> = 0<span>;
  46. </span><span>46</span> quick_sort( <span>$a</span><span> );
  47. </span><span>47</span> <span>}
  48. </span><span>48</span>
  49. <span>49</span> <span>$arr</span> = <span>range</span>( 9, 0<span> );
  50. </span><span>50</span> quick_sort( <span>$arr</span><span> );
  51. </span><span>51</span> <span>echo</span> <span>implode</span>( ', ', <span>$arr</span><span> );
  52. </span><span>52</span> ?>

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/910351.htmlTechArticleQuick Sort In-place Implementation,quicksort 在线运行PHPhttp://www.compileonline.com/execute_php_online.php 1 ? php 2 function swap( $a , $b ) 3 { 4 $c = $a ; 5 $a = $b ; 6 $...

人气教程排行