下記コードを元にしてクイックソートが実現できなくて困っています。
問題としてはQuickSort関数内で随時整列させていく配列データが保持していけないことです。
QuickSort関数が整列結果を返す形でもいいので
何かアドバイスいただけないでしょうか。
再帰処理でどういう順序で動いているのかは理解しています。
php
1<?php 2 3/** @var array 整列対象の配列 **/ 4$target = [5, 4, 7, 6, 8, 3, 1, 2, 9]; 5 6QuickSort($target, 0, count($target)-1); 7 8var_dump($target); //正しい整列結果が出る 9 10/* 11 * @param array 12 * @param ini 13 * @param int 14 * 15 */ 16function QuickSort(array $target, int $left, int $right) 17{ 18 19 $i = $left + 1; 20 $k = $right; 21 22 /* 23 * 基準値を値にしてデータを大小に分ける 24 */ 25 while ($i < $k) { 26 27 /** 28 * $iを使って、基準値より大きい要素を探す 29 */ 30 while ($target[$i] < $target[$left] && $i < $right) { 31 ++$i; 32 } 33 34 /** 35 * $kを使って、基準値より小さい要素を探す 36 */ 37 while ($target[$k] >= $target[$left] && $k > $left) { 38 --$k; 39 } 40 41 /** 42 * 大きいデータと小さいデータを変換する 43 */ 44 if ($i < $k) { 45 $swap = $target[$i]; 46 $target[$i] = $target[$k]; 47 $target[$k] = $swap; 48 } 49 50 } 51 52 if ($target[$left] > $target[$k]) { 53 $swap = $target[$left]; 54 $target[$left] = $target[$k]; 55 $target[$k] = $swap; 56 } 57 58 if ($left < $k-1) { 59 QuickSort($target, $left, $k-1); 60 } 61 62 if ($k+1 < $right) { 63 QuickSort($target, $k+1, $right); 64 } 65 66} 67
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/09/08 15:16