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

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;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,152评论 19 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,438评论 18 399
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 9,100评论 0 15
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,605评论 0 52
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,370评论 25 709

友情链接更多精彩内容