데이터 구조의 더미 정렬 C 언어 구현
// :
#include
#inlude
/****************************************************************************
:
: int i:
2*i+1: i
2*i+2: i
int len:
:
*******************************************************************************/
void HeapAdjust(int a[],int i,int len)
{
while( 2*i+1 < len )
{
int maxindex=2*i+1; // s
if(2*i+2// , Index
if(a[2*i+1]2*i+2])
{
maxindex=2*i+2;
}
}
if(a[i]/ / i 와 max index 의 데이터 교환
a[i]=a[i]^a[maxindex];
a[maxindex]=a[i]^a[maxindex];
a[i]=a[i]^a[maxindex];
/ / 더미 가 파괴 되 어 재 조정 이 필요 합 니 다.
i=maxindex;
}
else
{
/ / 좌우 아이들 이 모두 크 면 파괴 되 지 않 고 조정 이 필요 하지 않 습 니 다.
break;
}
}
return;
}
/ / 더미 정렬
void HeapSort(int a[],int len)
{
int i=0;
/ / a [0, Len - 1] 을 돔 으로 만든다.
for(i=len/2-1;i>=0;i--)
{
/ / 큰 지붕 쌓 기 함수 호출
HeapAdjust(a,i,len);
}
/ / n - 1 번 정렬 만 하면 됩 니 다.
for(i=len-1;i>0;i--)
{
/ / 글자 최대 기록 R [1] (즉, 쌓 기) 과 무질서 구역 의 마지막 기록 R [n] 을 교환 합 니 다.
a[0]=a[0]^a[i];
a[i]=a[0]^a[i];
a[0]=a[0]^a[i];
/ / a [0. i] 를 돔 으로 재 조정
HeapAdjust(a,0,i);
}
return;
}
int main(int argc, char const *argv[])
{
int a[]={45,569,213,123,12,56,45,56,10};
HeapSort(a,9);
int i;
for(i=0;i<9;i++)
{
printf("%d ",a[i]);
}
printf("");
return 0;
}
컴 파일 실행 결과 가 정확 합 니 다. 오류 가 있 으 면 지적 해 주 십시오.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
정수 반전Udemy 에서 공부 한 것을 중얼거린다 Chapter3【Integer Reversal】 (예) 문자열로 숫자를 반전 (toString, split, reverse, join) 인수의 수치 (n)가 0보다 위 또는 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.