文章

1

粉丝

316

获赞

0

访问

7.7k

头像
P1317堆排序+贪心
推荐阅读
P1371 吉林大学机试题
发布于2020年9月25日 20:40
阅读数 7.7k

哈夫曼编码问题
每次从数组中挑选出最小的两个数,将这两个数加入到体力消耗值,并将这两个数相加的结果放入数组,至到取完所有的元素
本题的关键在于如何取数组中最小的两个数:

首先可以排除qsort()和sort(),因为这两个库函数的时间复杂度均为O(nlogn),然后还需要遍历数组,总的时间复杂度在O(n^2logn),稳稳地超时

因为每次只需要取出最小的两个数,所以可以考虑使用小顶堆:建堆的时间复杂度为O(n),每次调整堆的时间复杂度为O(logn),总的时间复杂度为O(n+logn)

使用C++的话,使用优先队列即可实现小顶堆的功能
使用C的话,我们需要手动建堆

附上C语言代码:

#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define maxm (int)1e3
#define maxn (int)1e6
#define ms(a,b) memset(a,b,sizeof(a))
int a[maxn];
int n;
int INF=(1<<31)-1;
// 更改一个子树,使其变为小顶堆
void up_lheap(int l,int r)
{
    int father=l;
    int lson=l*2;
    int tmp=a[father];
    while(lson<=r)
    {
        if(a[lson]>a[lson+1]&&lson<r)
            lson++;
        if(tmp>a[lson])
        {
            a[father]=a[lson];
            father=lson;
            lson*=2;
        }
        else
            break;
    }
    a[father]=tmp;
}
// 得到一个完整的小顶堆
void create_heap()
...
登录查看完整内容


登录后发布评论

暂无评论,来抢沙发