[알고리즘]퀵 정렬(Quick Sort)

· 10년 전 · 1166

<?

// 퀵 정렬(Quick Sort)

function Swap(&$arr, $idx1, $idx2) {

$temp = $arr[$idx1];

$arr[$idx1] = $arr[$idx2];

$arr[$idx2] = $temp; 

}

 

// 중간값 찾기

function MedianOfThree($arr, $left, $right) {

$samples = array($left, floor(($left+$right)/2), $right);

if ($arr[$samples[0]] > $arr[$samples[1]])

Swap($samples, 0, 1);

if ($arr[$samples[1]] > $arr[$samples[2]])

Swap($samples, 1, 2);

if ($arr[$samples[0]] > $arr[$samples[1]])

Swap($samples, 0, 1);

 

return $samples[1];

}

 

function Partition(&$arr, $left, $right) {

$pIdx = MedianOfThree($arr, $left, $right); // 중간값으로 피벗 선택

$pivot = $arr[$pIdx];

 

$low = $left + 1;

$high = $right;

Swap($arr, $left, $pIdx); // 피벗을 가장 왼쪽으로 이동

 

while ($low <= $high) { // 교차되지 않을 때까지 반복

 

// 피벗보다 큰 값을 찾는 과정

while ($low <= $right  && $pivot >= $arr[$low])

$low++;

// 피벗보다 작은 값을 찾는 과정

while ($high >= ($left+1) && $pivot <= $arr[$high])  

$high--;

 

// 교차되지 않는 상태라면 Swap 실행

if ($low <= $high)

Swap($arr, $low, $high);

}

 

Swap($arr, $left, $high); // 피벗과 high 가 가리키는 대상 교환

return $high; // 옮겨진 피벗의 위치정보 교환

}

 

function QuickSort(&$arr, $left, $right) {

if ($left < $right) {

$pivot = Partition($arr, $left, $right); 

QuickSort($arr, $left, $pivot-1);

QuickSort($arr, $pivot+1, $right);

}

}

$arr = array(3, 2, 4, 1, 7, 6, 5);

$len = count($arr);

QuickSort($arr, 0, $len-1);

 

print_r($arr);

?>

|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
9년 전 조회 1,323
9년 전 조회 1,312
9년 전 조회 1,446
9년 전 조회 1,295
9년 전 조회 1,410
9년 전 조회 1,235
9년 전 조회 1,321
9년 전 조회 1,151
9년 전 조회 1,367
9년 전 조회 1,222
9년 전 조회 1,213
9년 전 조회 1,280
9년 전 조회 1,228
9년 전 조회 1,260
9년 전 조회 1,183
10년 전 조회 1,574
10년 전 조회 1,637
10년 전 조회 1,593
10년 전 조회 1,533
10년 전 조회 1,322
10년 전 조회 1,469
10년 전 조회 1,621
10년 전 조회 1,306
10년 전 조회 1,616
10년 전 조회 1,588
10년 전 조회 1,945
10년 전 조회 1,567
10년 전 조회 1,784
10년 전 조회 1,399
10년 전 조회 1,545
10년 전 조회 1,262
10년 전 조회 1,305
10년 전 조회 1,386
10년 전 조회 1,381
10년 전 조회 1,507
10년 전 조회 1,301
10년 전 조회 1,330
10년 전 조회 1,287
10년 전 조회 1,255
10년 전 조회 1,300
10년 전 조회 1,149
10년 전 조회 1,201
10년 전 조회 1,108
10년 전 조회 1,221
10년 전 조회 1,200
10년 전 조회 1,670
10년 전 조회 1,150
10년 전 조회 1,106
10년 전 조회 1,357
10년 전 조회 1,167
10년 전 조회 1,134
10년 전 조회 1,145
10년 전 조회 1,107
10년 전 조회 1,038
10년 전 조회 1,021
10년 전 조회 1,095
10년 전 조회 1,116
10년 전 조회 1,043
10년 전 조회 959
10년 전 조회 1,035
10년 전 조회 987
10년 전 조회 1,039
10년 전 조회 1,069
10년 전 조회 1,069
10년 전 조회 1,011
10년 전 조회 1,024
10년 전 조회 1,087
10년 전 조회 1,043
10년 전 조회 1,110
10년 전 조회 1,054
10년 전 조회 998
10년 전 조회 961
10년 전 조회 988
10년 전 조회 951
10년 전 조회 995
10년 전 조회 1,025
10년 전 조회 976
10년 전 조회 1,037
10년 전 조회 997
10년 전 조회 1,080
10년 전 조회 1,171
10년 전 조회 1,132
10년 전 조회 1,080
10년 전 조회 1,009
10년 전 조회 1,104
10년 전 조회 1,033
10년 전 조회 1,056
10년 전 조회 1,006
10년 전 조회 1,000
10년 전 조회 986
10년 전 조회 1,011
10년 전 조회 1,125
10년 전 조회 1,055
10년 전 조회 1,136
10년 전 조회 1,010
10년 전 조회 1,041
10년 전 조회 1,023
10년 전 조회 1,089
10년 전 조회 1,191
10년 전 조회 1,253