解题思路:转自:http://blog.csdn.net/lyy289065406/article/details/6647423  分析得非常好!!

利用Huffman思想,要使总费用最小,那么每次只选取最小长度的两块木板相加,再把这些“和”累加到总费用中即可

本题虽然利用了Huffman思想,但是直接用HuffmanTree做会超时,可以用优先队列做

因为朴素的HuffmanTree思想是:

(1)先把输入的所有元素升序排序,再选取最小的两个元素,把他们的和值累加到总费用

(2)把这两个最小元素出队,他们的和值入队,重新排列所有元素,重复(1),直至队列中元素个数<=1,则累计的费用就是最小费用

HuffmanTree超时的原因是每次都要重新排序,极度浪费时间,即使是用快排。

一个优化的处理是:

(1)只在输入全部数据后,进行一次升序排序  (以后不再排序)

(2)队列指针p指向队列第1个元素,然后取出队首的前2个元素,把他们的和值累计到总费用,再把和值sum作为一个新元素插入到队列适当的位置

由于原队首的前2个元素已被取出,因此这两个位置被废弃,我们可以在插入操作时,利用后一个元素位置,先把队列指针p+1,使他指向第2个废弃元素的位置,然后把sum从第3个位置开始向后逐一与各个元素比较,若大于该元素,则该元素前移一位,否则sum插入当前正在比较元素(队列中大于等于sum的第一个元素)的前一个位置

(3)以当前p的位置作为新队列的队首,重复上述操作

#include <iostream>
#include <fstream>
#include <cstdlib>using namespace std;__int64 sum,mincost;int cmp(const void* a,const void *b)
{return *(int*)a-*(int*)b;
}int main()
{int n,i,j;freopen("acm.txt","r",stdin);scanf("%d",&n);__int64 *w=new __int64[n+1];for(i=0; i<n; i++){scanf("%I64d",&w[i]);}qsort(w,n,sizeof(__int64),cmp);mincost=0;for(i=0; i<n-1; i++){sum=w[i]+w[i+1];  //最小两个和mincost+=sum;for(j=i+2; j<n; j++)  //
        {if(sum>w[j]){w[j-1]=w[j];  //向前移一位
            }else{w[j-1]=sum;  //在前面插入break;}}if(j==n) w[n-1]=sum;    //当大于所有的值,填充在最后
    }printf("%I64d\n",mincost);return 0;
}

转载于:https://www.cnblogs.com/Jason-Damon/archive/2012/04/14/2447813.html

poj3253 优先队列相关推荐

  1. POJ3253 Fence Repair【哈夫曼树+优先队列】

    Fence Repair Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 48026   Accepted: 15784 De ...

  2. poj3253切割木板(哈夫曼树) 贪心【优先队列】

    Fence Repair Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 37272   Accepted: 12078 De ...

  3. 树形结构 —— 优先队列

    [概述] priority_queue(优先队列)是定义在 <queue> 头文件中的一个模板类,其底层是用堆来实现的. 与 queue(队列)相比,优先队列不是按照入队顺序出队,而是按照 ...

  4. Vijos P1097 合并果子【哈夫曼树+优先队列】

    描述 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和.可以看 ...

  5. 优先队列的应用 C++实现

    优先队列的应用 C++实现 优先队列可以用堆来实现, 堆底层可以用数组表示, 通过索引关系,可以表示成一颗二叉完全树 C++的STL提供了相应的容器适配器 包含在queue头文件中 下面通过一道题来看 ...

  6. ccf 交通规划(迪杰斯特拉优先队列模板)

    什么跟什么就是刘汝佳小白书迪杰斯特拉队列的优先队列法 #include<bits/stdc++.h> using namespace std; #define INF 0x3f3f3f3f ...

  7. c++ std::priority_queue优先队列

    template <class T, class Container = vector<T>,class Compare = less<typename Container:: ...

  8. 《程序设计解题策略》——1.6 利用左偏树实现优先队列的合并

    本节书摘来自华章计算机<程序设计解题策略>一书中的第1章,第1.6节,作者:吴永辉 王建德 更多章节内容可以访问云栖社区"华章计算机"公众号查看. 1.6 利用左偏树实 ...

  9. 排序(一)归并、快排、优先队列等(图文具体解释)

    排序(一) 0基础排序算法 选择排序 思想:首先,找到数组中最小的那个元素.其次,将它和数组的第一个元素交换位置.再次.在剩下的元素中找到最小的元素.将它与数组的第二个元素交换位置. 如此往复,直到将 ...

最新文章

  1. C++STL源代码学习(之slist篇)
  2. Linux EOF使用
  3. ROS探索总结(四)(五)(六)——简单的机器人仿真 创建简单的机器人模型smartcar 使用smartcar进行仿真
  4. Okhttp-interceptor源码分析,快上车!
  5. The Triangle
  6. python发送文件到服务器_python 使用poster模块进行http方式的文件传输到服务器的方法...
  7. 给某社区技术写作大赛当评委,我的个人资料
  8. python下载邮箱附件_基于Python3 下载邮箱附件,并解压到指定文件夹
  9. 在Wordpress的文章页面获取上一页及下一页的链接URL地址,实现通过键盘的前进后退键进行翻页
  10. 索引sql server_SQL Server报告– SQL Server索引利用率
  11. cmake 常见问题及解决
  12. 查看linux系统语言并修改
  13. 磁共振中的T1, T2 和 T2*的原理和区别
  14. python矩阵乘法代码_python3 单行代码实现矩阵相乘
  15. Banner大小之国际标准
  16. STM32CubeMX | 36 - 使用CAN总线进行双板通信(TJA1050)
  17. 为什么手机网速太慢_手机网速慢怎么回事?一分钟就提速两倍的方法
  18. Java中为按钮添加监听器(事件处理)四种形式总结
  19. 基于STM32的五子棋游戏
  20. EMMC 擦除组的理解

热门文章

  1. sqlserver中删除重复行的方法
  2. 深入BCB理解VCL的消息机制
  3. #pragma与__pragma的区别与联系2009-01-19 15:47__pragma与#pragma的功能相同,所不同的是:
  4. 解决 Visual Studio 2019 无法打开wpf设计器问题
  5. 【C语言】动态分配二维字符串数组
  6. windows 包管理器scoop的使用
  7. springboot集成kaptcha 2.3.2
  8. Hi3516A开发--编译内核、uboot
  9. stl-优先队列priority_queue
  10. oracle用户手册在哪里,Oracle用户管理常用操作参考手册