NYOJ 55 懒省事的小明(哈弗曼树)
懒省事的小明
- 描写叙述
- 小明非常想吃果子,正好果园果子熟了。
在果园里,小明已经将全部的果子打了下来,并且按果子的不同种类分成了不同的堆。小明决定把全部的果子合成一堆。
由于小明比較懒。为了省力气,小明開始想点子了:
每一次合并,小明能够把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和。能够看出,全部的果子经过n-1次合并之后。就仅仅剩下一堆了。
小明在合并果子时总共消耗的体力等于每次合并所耗体力之和。
由于还要花大力气把这些果子搬回家,所以小明在合并果子时要尽可能地节省体力。假定每一个果子重量都为1,而且已知果子的种类数和每种果子的数目,你的任务是设计出合并的次序方案,使小明耗费的体力最少,并输出这个最小的体力耗费值。比如有3种果子,数目依次为1,2。9。
能够先将1、2堆合并。新堆数目为3。耗费体力为3。
接着。将新堆与原先的第三堆合并。又得到新的堆,数目为12,耗费体力为12。所以小明总共耗费体力=3+12=15。
能够证明15为最小的体力耗费值。
- 输入
- 第一行输入整数N(0<N<=10)表示測试数据组数。接下来每组測试数据输入包括两行,第一行是一个整数n(1<=n<=12000),表示果子的种类数。
第二行包括n个整数,用空格分隔,第i个整数ai(1<=ai<=20000)是第i种果子的数目。
- 输出
- 每组測试数据输出包括一行,这一行仅仅包括一个整数,也就是最小的体力耗费值。
- 例子输入
-
1
3
1 2 9 - 例子输出
-
15
測试了非常多次。没有AC的原因果然是以下代码中凝视的部分
#include <iostream>
#include <algorithm> using namespace std; int main()
{
int n,m,i,j;
long long k,t;
cin>>n;
while(n--)
{
cin>>m;
long long *ans=new long long[m];
for(i=0;i<m;++i)
cin>>ans[i]; sort(ans,ans+m); k=0;
for(i=1;i<m;++i)
{
k=k+ans[i]+ans[i-1];
j=i+1;
ans[i]=ans[i]+ans[i-1];
while(ans[j-1]>ans[j] && j<m)
{
/* ans[j-1]=ans[j]^ans[j-1];
ans[j]=ans[j]^ans[j-1];
ans[j-1]=ans[j]^ans[j-1]; */
t=ans[j];
ans[j]=ans[j-1];
ans[j-1]=t; j++;
}
}
cout<<k<<endl;
}
return 0;
}
哎。好好学 计算机组成原理 吧!
NYOJ 55 懒省事的小明(哈弗曼树)的更多相关文章
- nyoj 55 懒省事的小明【优先队列】
懒省事的小明 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...
- nyoj 55 懒省事的小明 优先队列 multiset 还有暴力
懒省事的小明 时间限制: 3000 ms | 内存限制: 65535 KB 难度: 3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的 ...
- nyoj 55 懒省事的小明(priority_queue优先队列)
懒省事的小明 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...
- ACM 懒省事的小明
懒省事的小明 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...
- 懒省事的小明--nyoj55
懒省事的小明 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种类分成 ...
- ny55 懒省事的小明
懒省事的小明 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而 ...
- 【ACM】懒省事的小明
懒省事的小明 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...
- ACM题目————STL练习之 懒省事的小明(优先队列)
描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.小明决定把所有的果子合成一堆. 因为小明比较懒,为了省力气,小明开始想点子了: 每一 ...
- NYOJ 55-懒省事的小明
点击打开链接 懒省事的小明 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果 ...
随机推荐
- zabbix3.0.4 部署之八 (zabbix3.0.4 报警前端配置)
(如何让报警信息推送----微信.邮件)(邮件与微信一样就不在重复) 创建一个用户 将用户加入administrator组 添加之前设置的报警媒介脚本 设置报警等级 创建动作 配置报警内容 设置报警条 ...
- Node.js+Express+MVC+Mysql小白创建新项目
1.打开CMD命令窗口,这一步不会的,回家休息,不要看了 2.npm install -g yo 等待时间看个人电脑情况. 如果没有npm命令,建议先安装npm ,npm安装介绍:https://d ...
- date - 打印或设置系统日期和时间
总览 date [选项]... [+格式] date [选项] [MMDDhhmm[[CC]YY][.ss]] 描述 根据指定格式显示当前时间或设置系统时间. -d, --date=STRING 显示 ...
- eclipse修改xml文件默认的打开方式为XML Editor
1.菜单:Window -> Preferences -> General -> Editors -> File Associations ...
- JavaScript exec()方法
exec() 方法用于检索字符串中的正则表达式的匹配.返回一个数组,其中存放匹配的结果.如果未找到匹配,则返回值为 null. var str = "我今年25岁明年26岁后年27岁千年24 ...
- Java中Date类型的工具类
package com.mytripod.util; import java.text.DateFormat; import java.text.SimpleDateFormat; import ja ...
- 零基础入门学习Python(2)--用Python设计第一个游戏
前言 小甲鱼的Python课程都是围绕着一个个小游戏,进行Python的讲解,由易入难. 小游戏流程图 Created with Raphaël 2.1.2Startprint('---------- ...
- HTTP实验:分别使用httpd-2.2和httpd-2.4实现
1. 需求描述 1.建立httpd服务,要求: (1) 提供两个基于名称的虚拟主机: www1.stuX.com,页面文件目录为/web/vhosts/www1:错误日志为/var/log/httpd ...
- 在Linux中CSV转换成XLSX
在linux中,把csv文件转换成excel表格(xlsx或者xls) $ echo -e 'surname,name,age\nCarlo,Smith,23\nJohn,Doe,46\nJane,D ...
- centos6 用户登陆管理
查看当前登陆有哪些用户,在做什么 [root@web01 ~]# w :: up :, users, load average: 0.00, 0.00, 0.00 USER TTY FROM LOGI ...