懒省事的小明

时间限制:3000 ms  |  内存限制:65535 KB
难度:3
描写叙述
      小明非常想吃果子,正好果园果子熟了。

在果园里,小明已经将全部的果子打了下来,并且按果子的不同种类分成了不同的堆。小明决定把全部的果子合成一堆。

由于小明比較懒。为了省力气,小明開始想点子了:

  每一次合并,小明能够把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和。

能够看出,全部的果子经过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 懒省事的小明(哈弗曼树)的更多相关文章

  1. nyoj 55 懒省事的小明【优先队列】

    懒省事的小明 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述       小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...

  2. nyoj 55 懒省事的小明 优先队列 multiset 还有暴力

    懒省事的小明 时间限制: 3000 ms  |  内存限制: 65535 KB 难度: 3   描述       小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的 ...

  3. nyoj 55 懒省事的小明(priority_queue优先队列)

    懒省事的小明 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述       小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...

  4. ACM 懒省事的小明

    懒省事的小明 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述       小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...

  5. 懒省事的小明--nyoj55

    懒省事的小明 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述      小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种类分成 ...

  6. ny55 懒省事的小明

    懒省事的小明 时间限制:3000 ms  |            内存限制:65535 KB 难度:3 描述       小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而 ...

  7. 【ACM】懒省事的小明

    懒省事的小明 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述       小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...

  8. ACM题目————STL练习之 懒省事的小明(优先队列)

    描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.小明决定把所有的果子合成一堆. 因为小明比较懒,为了省力气,小明开始想点子了: 每一 ...

  9. NYOJ 55-懒省事的小明

    点击打开链接 懒省事的小明 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述       小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果 ...

随机推荐

  1. zabbix3.0.4 部署之八 (zabbix3.0.4 报警前端配置)

    (如何让报警信息推送----微信.邮件)(邮件与微信一样就不在重复) 创建一个用户 将用户加入administrator组 添加之前设置的报警媒介脚本 设置报警等级 创建动作 配置报警内容 设置报警条 ...

  2. Node.js+Express+MVC+Mysql小白创建新项目

    1.打开CMD命令窗口,这一步不会的,回家休息,不要看了 2.npm install -g yo  等待时间看个人电脑情况. 如果没有npm命令,建议先安装npm ,npm安装介绍:https://d ...

  3. date - 打印或设置系统日期和时间

    总览 date [选项]... [+格式] date [选项] [MMDDhhmm[[CC]YY][.ss]] 描述 根据指定格式显示当前时间或设置系统时间. -d, --date=STRING 显示 ...

  4. eclipse修改xml文件默认的打开方式为XML Editor

    1.菜单:Window   ->   Preferences   ->   General   ->   Editors   ->   File   Associations  ...

  5. JavaScript exec()方法

    exec() 方法用于检索字符串中的正则表达式的匹配.返回一个数组,其中存放匹配的结果.如果未找到匹配,则返回值为 null. var str = "我今年25岁明年26岁后年27岁千年24 ...

  6. Java中Date类型的工具类

    package com.mytripod.util; import java.text.DateFormat; import java.text.SimpleDateFormat; import ja ...

  7. 零基础入门学习Python(2)--用Python设计第一个游戏

    前言 小甲鱼的Python课程都是围绕着一个个小游戏,进行Python的讲解,由易入难. 小游戏流程图 Created with Raphaël 2.1.2Startprint('---------- ...

  8. HTTP实验:分别使用httpd-2.2和httpd-2.4实现

    1. 需求描述 1.建立httpd服务,要求: (1) 提供两个基于名称的虚拟主机: www1.stuX.com,页面文件目录为/web/vhosts/www1:错误日志为/var/log/httpd ...

  9. 在Linux中CSV转换成XLSX

    在linux中,把csv文件转换成excel表格(xlsx或者xls) $ echo -e 'surname,name,age\nCarlo,Smith,23\nJohn,Doe,46\nJane,D ...

  10. centos6 用户登陆管理

    查看当前登陆有哪些用户,在做什么 [root@web01 ~]# w :: up :, users, load average: 0.00, 0.00, 0.00 USER TTY FROM LOGI ...