美文网首页
[数据结构]堆排序 解题报告

[数据结构]堆排序 解题报告

作者: vouv | 来源:发表于2017-03-26 14:30 被阅读0次

Problem Description

实验要求:用堆排序算法按关键字递减的顺序排序。
程序输入:待排序记录数(整数)和待排序记录(整数序列);

程序输出:建堆结果和建堆后第一、第二次筛选结果。(注:待排序记录数大于等于3)


测试输入

6
11
12
16
14
15
10

测试输出

16 15 11 14 12 10 
15 14 11 10 12 
14 12 11 10 

AcCode

//
//  main.cpp
//  堆排序
//
//  Created by jetviper on 2017/3/26.
//  Copyright © 2017年 jetviper. All rights reserved.
//

#include <stdio.h>

int arr[10000]={0};
int n;

void sorting(int len,int t)
{
    int  i=2*len;
    int tmp=arr[len];
    while(1)
    {
        if(i>t)break;
        
        if(i<t && arr[i]<arr[i+1])i++;
        
        if(tmp>=arr[i])i=t+1;
        
        else  {
            arr[len]=arr[i];
            len=i;
            i*=2;
        }
    }
    arr[len]=tmp;
    return;
}

int main()
{
    scanf("%d",&n);
    
    for(int i=1;i<=n;i++)scanf("%d",&arr[i]);
    
    for(int i=0;i<3;i++){
        for(int len=n/2;len>=1;len--)sorting(len,n);
        for(int i=1;i<=n;i++)printf("%d ",arr[i]);
        printf("\n");
        arr[1]=arr[n];
        n--;
    }
    
    return 0;
}

相关文章

  • [数据结构]堆排序 解题报告

    Problem Description 实验要求:用堆排序算法按关键字递减的顺序排序。程序输入:待排序记录数(整数...

  • 算法与数据结构(六):堆排序

    title: 算法与数据结构(六):堆排序tags: [算法与数据结构, C语言, 堆排序]date: 2019-...

  • 排序算法-堆排序

    参考: Java排序算法(五):堆排序 【算法与数据结构】图说堆排序 【数据结构】排序算法:希尔、归并、快速、堆排...

  • java堆排序

    什么是堆排序:图解堆排序堆排序:利用了堆这种数据结构堆数据结构:特殊的完全二叉树,因为具有以下的特点:1)每个结点...

  • 堆排序

    hello,你好,欢迎来到堆排序!堆排序是典型的数据结构和算法的结合,首先使用数据结构记录了必要的信息,然后算法通...

  • C++基础入门之模板堆排序(上):模板上的list的创造与操作

    整段源码链接C++的模板元堆排序 要点 组建数据结构list 组建对list的各种基本操作 堆排序中组建堆排序个个...

  • python实现堆排序(HeapSort)

    python实现【堆排序】(HeapSort) 算法原理及介绍 堆排序(Heapsort)是指利用堆这种数据结构所...

  • 堆排序

    转载:图解排序算法(三)之堆排序 预备知识 堆排序 堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选...

  • [数据结构]游戏2048 解题报告

    Problem Description 《2048》是一款数字益智游戏,在4*4的方格中通过上下左右滑动来控制数字...

  • [数据结构]约瑟夫问题 解题报告

    Problem Description (本题要求用循环链表实现) 约瑟夫问题是一个经典的问题。已知n个人(不妨分...

网友评论

      本文标题:[数据结构]堆排序 解题报告

      本文链接:https://www.haomeiwen.com/subject/ybckottx.html