[luoguP1090][Noip2004]合并果子
合并果子
首先来看一下题目:
(OI2004合并果子)
【题目描述】
果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆。多多决定把所有的果子合成一堆
每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和。可以看出,所有的果子经过n-1次合并之后,就只剩下一堆了。多多在合并果子时总共消耗的体力等于每次合并所耗体力之和.
因为还要花大力气把这些果子搬回家,所以多多在合并果子时要尽可能地节省体力。假定每个果子重量都为1,并且已知果子的种类数和每种果子的数目,你的任务是设计出合并的次序方案,使多多耗费的体力最少,并输出这个最小的体力耗费值。
例如有3种果子,数目依次为1,2,9。可以先将1、2堆合并,新堆数目为3,耗费体力为3。接着,将新堆与原先的第三堆合并,又得到新的堆,数目为12,耗费体力为12。所以多多总共耗费体力=3+12=15。可以证明15为最小的体力耗费值。
【输入格式】
第一行:一个数n,表示果子的堆数。
第二行:n个数ai,表示每堆果子的果子个数。
【输出格式】
一个数:多多所要花费的最小的体力。
【数据范围】:
n≤100000
【输入样例1】
3
1 2 9
【输出样例1】
15
【输入样例2】
10
3 5 1 7 6 4 2 5 4 1
【输出样例2】
120
这个题就用到了堆的思想。按照一般的思想来打代码,应该是每一次合并之后就从大到小拍一遍序,接着合并。按照这样的思路,答案是没有错的,但是时间复杂度就会十分的高。下面附一下普通思路的合并果子的代码:
#include<iostream>
#include<cstdio>
#include<algorithm>
#define MAXN 100010
using namespace std;
},total=;
int cmp(int x,int y)
{
return x>y;
}
int main()
{
scanf("%d",&n);
;i<=n;i++)
scanf("%d",&heavy[i]);
sort(heavy+,heavy+n+,cmp);
;i<=n;i++)
{
heavy[i]+=heavy[i-];
heavy[i-]=;
sort(heavy+,heavy+n+,cmp);
energy[i]=heavy[i]+heavy[i-];
}
;i<=n-;i++)
total+=energy[i];
printf("%d",total);
;
}
那么在这里就用到了堆(不懂堆的小朋友:详见->《堆》)
那么思路是这样的:
首先这个问题比较模糊,所以我们可以将它的问题描述转化一下:给了n个节点(即果子堆数),每一个节点有一个权值w[i](每一个堆的果子个数),我们要做的就是将其中的两个合并为一棵树, 假设每一个节点到根节点的距离为d[i],那么我们就要使得最终的∑(w[i]*d[i])最小(不懂∑的请点这里->《希腊字母在数学计算中表示的含义》)。那么具体的方法就是这样的:
- 从这个森林里面取出两个权值最小的节点。
- 将他们的权值相加,得到一个新的子树,然后删除原子树。
- 将当前得到的新子树插入到森林中然后维护。
- 不断重复1~3直到整个森林里面只有一棵树为止。
所以这里最重要的其实就是两个操作:取出get()和插入put()。
但是由于取出只能取出根节点,二我们要取出的还必须是权值最小的节点,所以我们要制作一个小根堆。
下面附上代码:
#include<iostream>
#include<cstdio>
using namespace std;
int heap_size,n;
];
void swip(int &a,int &b)
{
;a=b;b=t;
}
void put(int d)
{
int now,next;
heap[++heap_size]=d;
now=heap_size;
)
{
next=now>>;
if(heap[now]>=heap[next]) return;
swap(heap[now],heap[next]);
now=next;
}
}
int get()
{
int now,next,res;
res=heap[];
heap[]=heap[heap_size--];
now=;
<=heap_size)
{
next=now*;
]<heap[next]) next++;
if(heap[now]<heap[next]) return res;
swap(heap[now],heap[next]);
now=next;
}
return res;
}
void work()
{
;
scanf("%d",&n);
;i<=n;i++)
{
scanf("%d",&x);
put(x);
}
;i<n;i++)
{
x=get();
y=get();
ans+=x+y;
put(x+y);
}
printf("%d",ans);
}
int main()
{
work();
;
}
[luoguP1090][Noip2004]合并果子的更多相关文章
- NC16663 [NOIP2004]合并果子
NC16663 [NOIP2004]合并果子 题目 题目描述 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可 ...
- NOIP2004合并果子
题目描述 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和.可 ...
- 合并果子(NOIP2004)
合并果子(NOIP2004)[问题描述]在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆.每一次合并,多多可以把两堆果子合并到一起,消耗的体 ...
- [Noip2004][Day ?][T?]合并果子(?.cpp)
题目描述 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和.可 ...
- [NOIP2004] 提高组 洛谷P1090 合并果子
题目描述 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和.可 ...
- 加强版:合并果子[NOIP2004]
题目 链接:https://ac.nowcoder.com/acm/contest/26887/1001 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K, ...
- 合并果子 (codevs 1063) 题解
[问题描述] 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和 ...
- 代码源 每日一题 分割 洛谷 P6033合并果子
题目链接:切割 - 题目 - Daimayuan Online Judge 数据加强版链接: [NOIP2004 提高组] 合并果子 加强版 - 洛谷 题目描述 有一个长度为 ∑ai 的木板,需要 ...
- 【noip 2004】 合并果子
noip2016结束后的第一份代码--优先队列的练习 合并果子 原题在这里 #include <iostream> #include <queue> #include < ...
随机推荐
- java多态简单例子
/* 对象的多态性:动物 x = new 猫(); 函数的多态性:函数重载.重写 1.多态的体现 父类的引用指向了自己的子类对象 父类的引用也可以接收自己的对象 2.多态的前提 必须是类与类之间只有关 ...
- 如何在ThinkPHP中开启调试模式
1.为什么使用调试模式? 因为调试会在我们的模板页的最后增加一些trace信息. 2.什么是trace信息? 是ThinkPHP为我们提供好的一些包含了系统运行时间.占用内存.加载时间.请求的协议.. ...
- Flask 编写http接口api及接口自动化测试
片言 此文中代码都是笔者工作中源码,所以不会很完整,主要摘常见场景的api片段用以举例说明 另:此文主要针对自动化测试人员,尤其有python基础阅读更佳. 笔者使用 python3.6 + post ...
- AI从入门到放弃:CNN的导火索,用MLP做图像分类识别?
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:郑善友 腾讯MIG后台开发工程师 导语:在没有CNN以及更先进的神经网络的时代,朴素的想法是用多层感知机(MLP)做图片分类的识别:但 ...
- UML建模—EA的使用起步
Enterprise Architect(EA) 是一个功能比较强悍的建模工具. 对于一个软件设计者来说,从需求分析到业务设计.类模型设计.数据库设计到测试.发布.部署等一系列软件设计必须的操作都可以 ...
- Java线程同步打印ABC
需求: 三个线程,依次打印ABCABCABC.... 方案一: 使用阻塞队列,线程1从队列1获取内容打印,线程2从队列2获取内容打印,线程3从队列3中获取内容打印.线程1把B放到队列3中,线程2把C放 ...
- Python爬虫之requests模块(1)
一.引入 Requests 唯一的一个非转基因的 Python HTTP 库,人类可以安全享用. 警告:非专业使用其他 HTTP 库会导致危险的副作用,包括:安全缺陷症.冗余代码症.重新发明轮子症.啃 ...
- Android 自定义View实现SegmentControlView(自定义多样式tablayout)
偷懒一下,不做过多阐述 参考资源: Android 自定义View实现SegmentControlView : https://blog.csdn.net/a512337862/article/det ...
- 【MATLAB】R2017b两个镜像文件如何安装
1.采用DEAMON TOOLS加载镜像1. 2.当安装过程中弹出[请插入DVD2]时,在原来的盘符上面右键点击[装载],选择DVD2的镜像文件.在安装程序处选择[继续]即可正常安装.
- 用Webstorm 运行React-native 工程时,出错:xcrun: error: unable to find utility "instruments", not a developer tool or in PATH
解决方法:在 终端执行如下命令 sudo xcode-select -s /Applications/Xcode.app/Contents/Developer/ 注意:前提是你已经安装了xcode