힙 알고리즘

(Heap)의 알고리즘은 n개체의 가능한 모든 순열을 생성한다. 1963년 (B.R. Heap)에 의해 처음 제안되었다.[1]이 알고리즘의 주요한 특징은 움직임을 최소화한다는 것이다. 단일 요소 쌍을 교환하여 이전 순열에서 각 순열을 생성함으로써 이러한 결과를 갖을수있다. 다른 n-2 요소는 방해받지 않는다. 순열 생성 알고리즘에 대한 1977년 검토에서 로버트 세지윅(Robert Sedgewick)은 당시 컴퓨터로 순열을 생성하는 데 가장 효과적인 알고리즘이라고 결론지은바있다.[2]

힙의 알고리즘에 의해 생성된 n개 객체의 순열 시퀀스는 n + 1 객체의 순열 시퀀스의 시작이다. 따라서 힙(Heap) 알고리즘(OEIS의 시퀀스 A280318)에 의해 생성된 무한 시퀀스의 순열이 계산된바 있다.

n(3)개의 원소를 갖는 집합에서의 순열의 경우의 수를 보여주는 힙 알고리즘을 사용한 자바스크립트 프로그램

<html><script>function permute(permutation) { var length = permutation.length ; var    result =   permutation.slice()  ; var    c = new Array(length).fill(0) ;  var   i = 1, k, p; while (i < length) {   if (c[i] < i) {     k =  i%2 && c[i];     p = permutation[i];     permutation[i] = permutation[k];     permutation[k] = p;     c[i]++;     i = 1;     result.push(  permutation.slice());   } else {     c[i] = 0;     i++;   } } return result;}window.onload = function () {document.write(permute([1, 2, 3]));}</script></html>
결과 1,2,3, 2,1,3, 3,1,2, 1,3,2, 2,3,1, 3,2,1

힙정렬

힙(Heap)알고리즘은 힙정렬(heap sort)과 다르지만 다른 n-2 요소는 방해받지 않는다는 스왑 알고리즘(swap algorithm)을 보여준다는 점에서 비교할만한 유용한 유사한 점도 있다.

같이 보기

각주

Brown Unwersity, Prowdence, Rhode Island 02912)http://homepage.math.uiowa.edu/~goodman/22m150.dir/2007/Permutation%20Generation%20Methods.pdf