栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

838. 堆排序

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

838. 堆排序

输入一个长度为 nn 的整数数列,从小到大输出前 mm 小的数。

输入格式

第一行包含整数 nn 和 mm。

第二行包含 nn 个整数,表示整数数列。

输出格式

共一行,包含 mm 个整数,表示整数数列中前 mm 小的数。

数据范围

1≤m≤n≤1051≤m≤n≤105,
1≤数列中元素≤1091≤数列中元素≤109

输入样例:

5 3
4 5 1 3 2

输出样例:

1 2 3
1,代码
#include 
#include 
#include 
using namespace std;
#define int long long
const int N = 1e5+1;
int a[N];
int Size=0;
void down(int k)
{
    int t=k;
    if(k*2<=Size&&a[k*2]> n>>m;
    Size=n;
    for (int i = 1; i <= n; i ++ )
    {
        cin >> a[i];
    }
    for (int i = n/2; i ; i -- )down(i);
    
    for (int i = m; i ; i -- )
    {
        cout<
2,堆是完全二叉树

a[1]

a[2] a[3]

a[4] a[5] a[6] a[7]

......

up();

down() ;

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/513169.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号