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

· 9년 전 · 475

<?

// 퀵 정렬(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년 전 조회 534
9년 전 조회 535
9년 전 조회 674
9년 전 조회 491
9년 전 조회 627
9년 전 조회 454
9년 전 조회 508
9년 전 조회 395
9년 전 조회 591
9년 전 조회 480
9년 전 조회 489
9년 전 조회 531
9년 전 조회 492
9년 전 조회 494
9년 전 조회 456
9년 전 조회 840
9년 전 조회 880
9년 전 조회 857
9년 전 조회 782
9년 전 조회 577
9년 전 조회 749
9년 전 조회 871
9년 전 조회 558
9년 전 조회 854
9년 전 조회 818
9년 전 조회 1,211
9년 전 조회 828
9년 전 조회 1,021
9년 전 조회 678
9년 전 조회 810
9년 전 조회 570
9년 전 조회 553
9년 전 조회 677
9년 전 조회 645
9년 전 조회 827
9년 전 조회 537
9년 전 조회 620
9년 전 조회 569
9년 전 조회 509
9년 전 조회 587
9년 전 조회 453
9년 전 조회 488
9년 전 조회 444
9년 전 조회 511
9년 전 조회 492
9년 전 조회 933
9년 전 조회 462
9년 전 조회 392
9년 전 조회 652
9년 전 조회 476
9년 전 조회 475
9년 전 조회 438
9년 전 조회 409
9년 전 조회 364
9년 전 조회 342
9년 전 조회 401
9년 전 조회 419
9년 전 조회 368
9년 전 조회 310
9년 전 조회 416
9년 전 조회 357
9년 전 조회 385
9년 전 조회 409
9년 전 조회 445
9년 전 조회 328
9년 전 조회 377
9년 전 조회 430
9년 전 조회 363
9년 전 조회 480
9년 전 조회 409
9년 전 조회 347
9년 전 조회 313
9년 전 조회 364
9년 전 조회 315
9년 전 조회 348
9년 전 조회 377
9년 전 조회 309
9년 전 조회 361
9년 전 조회 327
9년 전 조회 430
9년 전 조회 523
10년 전 조회 482
10년 전 조회 428
10년 전 조회 375
10년 전 조회 448
10년 전 조회 382
10년 전 조회 405
10년 전 조회 355
10년 전 조회 327
10년 전 조회 328
10년 전 조회 360
10년 전 조회 427
10년 전 조회 392
10년 전 조회 443
10년 전 조회 375
10년 전 조회 374
10년 전 조회 375
10년 전 조회 413
10년 전 조회 498
10년 전 조회 600
🐛 버그신고