Chinaunix首页 | 论坛 | 博客
  • 博客访问: 356903
  • 博文数量: 135
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1106
  • 用 户 组: 普通用户
  • 注册时间: 2013-03-20 09:56
文章分类

全部博文(135)

文章存档

2017年(3)

2016年(18)

2015年(69)

2014年(39)

2013年(6)

我的朋友

分类: C/C++

2015-10-03 23:13:40

#include <iostream>

using namespace std;

void sift(int a[], int k, int m)
{
    int i = k;
    int j = 2 * i + 1;

    while (j < m-1)
    {
        if (j < m-1 && a[j] < a[j+1]) j++;
        if (a[i] > a[j]) break;
        else
        {
            int temp = a[i];
            a[i] = a[j];
            a[j] = temp;
            i = j;
            j = 2 * i + 1;
        }
    }
}

void heapsort(int a[], int n)
{
    int i = 0;
    int j = 0;

    for (i = n/2; i>=0; i--)
        sift(a, i, n);

    for (j = 1; j < n; j++)
    {
        int temp = a[0];
        a[0] = a[n-j];
        a[n-j] = temp;
        sift(a, 0, n-j);
    }
}

int main(void)
{
    int k = 0;
    int a[11] = {10, 4, 9, 40, 11, 66, 32, 21, 99, 33, 6};
    heapsort(a, 11);
    for (k = 0; k < 11; k++)
        printf ("%d\t", a[k]);

    printf ("\n");

    return 0;
}

阅读(751) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~