首页 > 其他 > 详细

POJ 3253 Fence Repair(优先队列,哈夫曼树)

时间:2014-06-26 16:01:44      阅读:314      评论:0      收藏:0      [点我收藏+]

题目

 

//做哈夫曼树时,可以用优先队列(误?)

//这道题教我们优先队列的一个用法:取前n个数(最大的或者最小的)

 

bubuko.com,布布扣
//哈夫曼树
//64位
//超时->优先队列,,,,
//这道题的优先队列用于取前2个小的元素

#include <iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
using namespace std;

__int64 ans,a[20010];
int n;

struct cmp
{  
    bool operator ()(__int64 &a,__int64 &b){  
        return a>b;
    }  
};

priority_queue<__int64,vector<__int64>,cmp> q;

void hfm()
{
    
    __int64 min1,min2,neww,yi;
    while(n>1)
    {
        yi=0;
        min1=q.top();
        q.pop();
        min2=q.top();
        q.pop();
        neww=min1+min2;
        ans+=neww;
        q.push(neww);
        n--;
    }
}

int main()
{
    int i;
    while(scanf("%d",&n)!=EOF)
    {
        while(!q.empty())q.pop();
        for(i=0;i<n;i++)
        {
            scanf("%I64d",&a[i]);
            q.push(a[i]);
        }
        ans=0;
        if(n>1)
            hfm();
        else
            ans=a[0];
        printf("%I64d\n",ans);
    }
    return 0;
}
View Code

 

POJ 3253 Fence Repair(优先队列,哈夫曼树),布布扣,bubuko.com

POJ 3253 Fence Repair(优先队列,哈夫曼树)

原文:http://www.cnblogs.com/laiba2004/p/3808955.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!