BZOJ 1629 [Usaco2005 Nov]Cow Acrobats:贪心【局部证明】
题目链接:http://begin.lydsy.com/JudgeOnline/problem.php?id=1332
题意:
有n头牛在“叠罗汉”。
第i头牛的体重为w[i],力量为s[i]。
一头牛的压扁程度 = 它上面所有牛的体重之和 - s[i]
所有牛的总压扁程度 = 所有牛中最大的那个压扁程度
问你总压扁程度最小为多少。
题解:
贪心。
套路:
选取最小的一个单元——相邻的两头牛,进行贪心策略的局部证明。
贪心策略:
假设最左边为顶部,最右边为底部。
从左往右分别编号0...n-1。
考虑两头相邻的牛:交换i和i+1两头牛。
压扁程度(交换之前):
i: a = sum - s[i]
i+1: b = sum + w[i] - s[i+1]
压扁程度(交换之后):
i: a' = sum + w[i+1] - s[i]
i+1: b' = sum - s[i+1]
显然:在交换之前,b为两者最大值;交换之后,a'为两者最大值。
假设未交换时为最优状态,则交换后不可能更优。
所以有:b < a'
即:sum + w[i] - s[i+1] < sum + w[i+1] - s[i]
整理得:s[i+1] + w[i+1] > s[i] + w[i]
所以贪心策略为:w+s值越大,越放在底下。
AC Code:
// before:
// i: sum - s[i]
// i+1: sum + w[i] - s[i+1]
// after:
// i+1: sum - s[i+1]
// i: sum + w[i+1] - s[i]
//
// f1 < f4 +w[i+1]
// f2 > f3 -w[i]
// w[i] - s[i+1] < w[i+1] - s[i]
// w[i+1] + s[i+1] > w[i] + s[i]
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#define MAX_N 50005
#define INF 10000000 using namespace std; struct Cow
{
int w;
int s;
Cow(int _w,int _s)
{
w=_w;
s=_s;
}
Cow(){}
friend bool operator < (const Cow &a,const Cow &b)
{
return a.w+a.s<b.w+b.s;
}
}; int n;
Cow cow[MAX_N]; int main()
{
cin>>n;
for(int i=;i<n;i++)
{
cin>>cow[i].w>>cow[i].s;
}
sort(cow,cow+n);
int sum=;
int ans=-INF;
for(int i=;i<n;i++)
{
ans=max(ans,sum-cow[i].s);
sum+=cow[i].w;
}
cout<<ans<<endl;
}
BZOJ 1629 [Usaco2005 Nov]Cow Acrobats:贪心【局部证明】的更多相关文章
- bzoj 1629: [Usaco2007 Demo]Cow Acrobats【贪心+排序】
仿佛学到了贪心的新姿势-- 考虑相邻两头牛,交换它们对其他牛不产生影响,所以如果交换这两头牛能使这两头牛之间的最大值变小,则交换 #include<iostream> #include&l ...
- BZOJ 1629: [Usaco2007 Demo]Cow Acrobats
Description Farmer John's N (1 <= N <= 50,000) cows (numbered 1..N) are planning to run away a ...
- [USACO2005][POJ3045]Cow Acrobats(贪心)
题目:http://poj.org/problem?id=3045 题意:每个牛都有一个wi和si,试将他们排序,每头牛的风险值等于前面所有牛的wj(j<i)之和-si,求风险值最大的牛的最小风 ...
- POJ 3045 Cow Acrobats (贪心)
POJ 3045 Cow Acrobats 这是个贪心的题目,和网上的很多题解略有不同,我的贪心是从最下层开始,每次找到能使该层的牛的风险最小的方案, 记录风险值,上移一层,继续贪心. 最后从遍历每一 ...
- BZOJ 1641: [Usaco2007 Nov]Cow Hurdles 奶牛跨栏( floyd )
直接floyd.. ---------------------------------------------------------------------------- #include<c ...
- Cow Acrobats(贪心)
Cow Acrobats Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3686 Accepted: 1428 Desc ...
- BZOJ 1742: [Usaco2005 nov]Grazing on the Run 边跑边吃草( dp )
dp... dp( l , r , k ) , 表示 吃了[ l , r ] 的草 , k = 1 表示最后在 r 处 , k = 0 表示最后在 l 处 . ------------------- ...
- Bzoj 2058: [Usaco2010 Nov]Cow Photographs 题解
2058: [Usaco2010 Nov]Cow Photographs Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 190 Solved: 104[ ...
- 【BZOJ】1629: [Usaco2007 Demo]Cow Acrobats(贪心+排序)
http://www.lydsy.com/JudgeOnline/problem.php?id=1629 这题我想了很久都没想出来啊... 其实任意两头相邻的牛交换顺序对其它牛是没有影响的.. 那么我 ...
随机推荐
- mongodb管理副本集(持续更新中)
许多维护工作不能在备份节点上完成 因为要写操作,也不能在主节点上进行,这就需要单机模式启动服务器, 是指重启成员服务器,让他成为一个单机运行的服务器,而不再是副本集中的一员(临时的) 在单机 ...
- hdu4405Aeroplane chess 概率dp水题
//从0到n有n+1个格子 //对于格子i,掷一次骰子的数为x.那么能够从位置i到位置i+x //格子之间有连线,假设格子a和b有连线,那么从a到b不用掷骰子 //求从0到n的骰子掷的次数的期望 // ...
- 转 FreeBSD通过PORTS安装软件的几个常用命令
1.怎样找到我想安装的包路径:# cd /usr/ports# make search name=mysql2.仅仅下载源码包,而不安装:# cd /usr/ports/directory# make ...
- Allegro Desgin Compare的用法与网表比较
转:Allegro Desgin Compare的用法与网表比较 Allegro中自带有Design Compare工具,利用它可以比较明了的看到线路的差异.当然也可以通过SKILL进行比较,不过我们 ...
- java ConcurrentHashMap 初识
“ConcurrentHashMap是一个线程安全的哈希表“,但是不允许key和value为空: HashTable和ConcurrentHashMap都是线程安全的,但是HashTable是同步容器 ...
- sudo apt-get update 没有公钥,无法验证下列签名
在更新系统源后,输入sudo apt-get update之后出现提示: W: GPG 错误:http://archive.ubuntukylin.com:10006 xenial InRelease ...
- 网络工具的瑞士军刀netcat
这是一个聒噪的夜晚,假设要给出个原因.可能是由于尽管我认为西班牙不纯粹,可是怎么也不至于干为人家搭台面自己不唱戏的角色吧..结束以后.我认为该玩一下素有网络瑞士军刀之称谓的netcat了. 尽管瑞士军 ...
- ExtJs4学习(二):Dom操作
如今主流的JS框架要数ExtJs和JQuery应用的比較广泛.JQuery属于轻量级的,一般做站点应用比較常见.可见块头小的优势. ExtJs比較庞大,它除了对主要的JS语法和HTML DOM操作方式 ...
- jQuery 标签切换----之选项卡的实现
这一次,我自己写了代码,先看html部分: <div class="tab"> <div class="tab_menu"> <u ...
- hashmap和ConcurrentHashMap
hashmap市基于table和单向链表 table中存放hash值,table中存放着单向链表,查询时先计算对象hash值,找到table中对应值,然后查询链表. ConcurrentHashMap ...