[알고리즘]힙 정렬(Heap Sort)

· 10년 전 · 1287

<?php

class Heap {

    var $numOfData;

    var $heapArr = array();

    var $comp;

 

    function __construct($pc) { // 힙의 초기화

        $this->numOfData = 0;

        $this->comp = $pc;

    }

 

    function HIsEmpty() { // 힙이 비었는지 확인

        if ($this->numOfData == 0)

            return TRUE;

        else

            return FALSE;

    }

 

    function GetParentIDX($idx) { // 부모 노드의 인덱스 값 반환

        return floor($idx/2);

    }

 

    function GetLChildIDX($idx) { // 왼쪽 자식 노드의 인덱스 값 반환

        return $idx*2;

    }

 

    function GetRChildIDX($idx) { // 오른쪽 자식 노드의 인덱스 값 반환

        return $this->GetLChildIDX($idx)+1;

    }

 

// 두 개의 자식 노드중 높은 우선 순위의 자식 노드 인덱스 값 반환

    function GetHiPriChildIDX($idx) {

        if ($this->GetLChildIDX($idx) > $this->numOfData)

            return 0;

 

        else if ($this->GetLChildIDX($idx) == $this->numOfData)

            return $this->GetLChildIDX($idx);

 

        else

        {

            $comp = $this->comp;

            if ($comp($this->heapArr[$this->GetLChildIDX($idx)],

                $this->heapArr[$this->GetRChildIDX($idx)]) < 0)

                return $this->GetRChildIDX($idx);

            else

                return $this->GetLChildIDX($idx);

        }

    }

 

// 힙에 데이터 저장

    function HInsert($data) {

        $idx = $this->numOfData+1;

        $comp = $this->comp;

        while ($idx != 1) {

            if($comp($data, $this->heapArr[$this->GetParentIDX($idx)]) > 0) {

                $this->heapArr[$idx] = $this->heapArr[$this->GetParentIDX($idx)];

                $idx = $this->GetParentIDX($idx);

            }

            else

                break;

        }

        $this->heapArr[$idx] = $data;

        $this->numOfData += 1;

    }

// 힙에서 데이터 삭제

    function HDelete() {

        $retData = $this->heapArr[1];

        $lastElem = $this->heapArr[$this->numOfData];

 

        $parentIdx = 1;

        $childIdx;

        $comp = $this->comp;

        while ($childIdx = $this->GetHiPriChildIDX($parentIdx)) {

            if ($comp($lastElem, $this->heapArr[$childIdx]) >= 0)

                break;

 

            $this->heapArr[$parentIdx] = $this->heapArr[$childIdx];

            $parentIdx = $childIdx;

        }

 

        $this->heapArr[$parentIdx] = $lastElem;

        $this->numOfData -= 1;

        return $retData;

    }

}

 

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

 

// 오름차순

function PriorityComp($d1, $d2) {

    return $d2 - $d1;

}

 

$heap = new Heap(PriorityComp);

foreach ($arr as $val)

$heap->HInsert($val);

 

foreach ($arr as $k => $v) 

$arr[$k] = $heap->Hdelete();

 

print_r($arr);

?>


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

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
10년 전 조회 1,521
10년 전 조회 1,344
10년 전 조회 1,567
10년 전 조회 1,378
10년 전 조회 1,407
10년 전 조회 1,514
10년 전 조회 1,413
10년 전 조회 1,445
10년 전 조회 1,379
10년 전 조회 1,791
10년 전 조회 1,820
10년 전 조회 1,791
10년 전 조회 1,745
10년 전 조회 1,521
10년 전 조회 1,656
10년 전 조회 1,821
10년 전 조회 1,530
10년 전 조회 1,820
10년 전 조회 1,785
10년 전 조회 2,165
10년 전 조회 1,773
10년 전 조회 1,976
10년 전 조회 1,604
10년 전 조회 1,744
10년 전 조회 1,457
10년 전 조회 1,518
10년 전 조회 1,577
10년 전 조회 1,567
10년 전 조회 1,722
10년 전 조회 1,487
10년 전 조회 1,519
10년 전 조회 1,494
10년 전 조회 1,431
10년 전 조회 1,489
10년 전 조회 1,309
10년 전 조회 1,375
10년 전 조회 1,289
10년 전 조회 1,436
10년 전 조회 1,376
10년 전 조회 1,848
10년 전 조회 1,320
10년 전 조회 1,290
10년 전 조회 1,549
10년 전 조회 1,360
10년 전 조회 1,339
10년 전 조회 1,335
10년 전 조회 1,269
10년 전 조회 1,205
10년 전 조회 1,186
10년 전 조회 1,288
10년 전 조회 1,282
10년 전 조회 1,216
10년 전 조회 1,111
10년 전 조회 1,191
10년 전 조회 1,172
10년 전 조회 1,193
10년 전 조회 1,246
10년 전 조회 1,249
10년 전 조회 1,187
10년 전 조회 1,189
10년 전 조회 1,235
10년 전 조회 1,207
10년 전 조회 1,282
10년 전 조회 1,200
10년 전 조회 1,152
10년 전 조회 1,135
10년 전 조회 1,153
10년 전 조회 1,132
10년 전 조회 1,156
10년 전 조회 1,173
10년 전 조회 1,147
10년 전 조회 1,202
10년 전 조회 1,137
10년 전 조회 1,232
10년 전 조회 1,318
10년 전 조회 1,291
10년 전 조회 1,237
10년 전 조회 1,154
10년 전 조회 1,273
10년 전 조회 1,188
10년 전 조회 1,195
10년 전 조회 1,161
10년 전 조회 1,130
10년 전 조회 1,134
10년 전 조회 1,151
10년 전 조회 1,248
10년 전 조회 1,189
10년 전 조회 1,271
10년 전 조회 1,171
10년 전 조회 1,198
10년 전 조회 1,189
10년 전 조회 1,242
10년 전 조회 1,338
10년 전 조회 1,419
10년 전 조회 1,215
10년 전 조회 1,275
10년 전 조회 1,163
10년 전 조회 1,079
10년 전 조회 1,136
10년 전 조회 1,272