Tian Ji -- The Horse Racing HDU - 1052
Tian Ji -- The Horse Racing HDU - 1052
(有平局的田忌赛马,田忌赢一次得200块,输一次输掉200块,平局不得钱不输钱,要使得田忌得到最多(如果只能输就输的最少))
首先,实际是要求两人马的配对关系。那么不妨设齐王是按从快到慢的顺序出马的。因此先将齐王的马排序。
关键在于田忌最慢的马,能先赢就先赢,不能赢就去消耗齐王最快的马,
然后再来考虑最快的马,能先赢就先赢,不能赢说明现在田忌和齐王最快的
马和最慢的马都相等,再来考虑把田忌最慢的马和齐王最快的马比较。
可以发现,如果把过程当做田忌每次根据齐王出的马出一匹自己的马,那么他的的最佳策略一定是要么出剩下最快的马,要么出最慢的。(要么赢,要么消耗)
因此,把田忌的马也排一下序。之后定义ans[i][j]为齐王出i匹较强的,田忌出j匹较强的,i-j匹较弱的时能得到的最大收益。定义get(i,j)表示田忌的第i弱的马与齐王第j弱的马比,田忌得到的收益。那么ans[i][j]=max(ans[i-1][j]+get(i-j,n-i+1),ans[i-1][j-1]+get(n-j+1,n-i+1))。
小细节:
齐王出第i强的(第n-i+1弱的)时:
如果田忌出弱的,那么田忌已经出了j匹较强的,这一次出的是第i-j匹弱的
如果田忌出强的,那么这一次出的是第j强的(第n-j+1弱的)
对于ans[i][0]和ans[i][i]要特判,不然会越界访问。
这题有$O(nlogn)$(除去排序就是$O(n)$)的完全贪心做法。(仅做记录)
曾经错误:
1.把get里面的t1和t2打成全是t1。
2.进行动态规划的循环中前后两行特判写错,写成
ans[i][0]=ans[i-1][0]+get(i-j,n-i+1)
ans[i][i]=ans[i-1][i-1]+get(n-j+1,n-i+1)
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int ans[][];
int t1[],t2[];
int n,anss;
int get(int a,int b)
{
if(t1[a]>t2[b]) return ;
if(t1[a]==t2[b]) return ;
return -;
}
int main()
{
int i,j;
scanf("%d",&n);
while(n!=)
{
anss=-0x3f3f3f3f;
memset(ans,,sizeof(ans));
for(i=;i<=n;i++)
scanf("%d",&t1[i]);
for(i=;i<=n;i++)
scanf("%d",&t2[i]);
sort(t1+,t1+n+);
sort(t2+,t2+n+);
for(i=;i<=n;i++)
{
ans[i][]=ans[i-][]+get(i,n-i+);
for(j=;j<i;j++)
ans[i][j]=max(ans[i-][j]+get(i-j,n-i+),ans[i-][j-]+get(n-j+,n-i+));
ans[i][i]=ans[i-][i-]+get(n-i+,n-i+);
}
for(i=;i<=n;i++)
anss=max(anss,ans[n][i]);
printf("%d\n",anss);
scanf("%d",&n);
}
return ;
}
Tian Ji -- The Horse Racing HDU - 1052的更多相关文章
- HDU 1052 Tian Ji -- The Horse Racing (贪心)(转载有修改)
Tian Ji -- The Horse Racing Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (J ...
- Hdu 1052 Tian Ji -- The Horse Racing
Tian Ji -- The Horse Racing Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (J ...
- HDU 1052 Tian Ji -- The Horse Racing【贪心在动态规划中的运用】
算法分析: 这个问题很显然可以转化成一个二分图最佳匹配的问题.把田忌的马放左边,把齐王的马放右边.田忌的马A和齐王的B之间,如果田忌的马胜,则连一条权为200的边:如果平局,则连一条权为0的边:如果输 ...
- hdu 1052 Tian Ji -- The Horse Racing (田忌赛马)
Tian Ji -- The Horse Racing Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (J ...
- HDU 1052:Tian Ji -- The Horse Racing(贪心)
Tian Ji -- The Horse Racing Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...
- 杭州电 1052 Tian Ji -- The Horse Racing(贪婪)
http://acm.hdu.edu.cn/showproblem.php? pid=1052 Tian Ji -- The Horse Racing Time Limit: 2000/1000 MS ...
- hdoj 1052 Tian Ji -- The Horse Racing【田忌赛马】 【贪心】
思路:先按从小到大排序, 然后从最快的開始比(如果i, j 是最慢的一端, flag1, flag2是最快的一端 ),田的最快的大于king的 则比較,如果等于然后推断,有三种情况: 一:大于则比較, ...
- hdu1052 Tian Ji -- The Horse Racing 馋
转载请注明出处:http://blog.csdn.net/u012860063 题目链接:pid=1052">http://acm.hdu.edu.cn/showproblem.php ...
- Tian Ji -- The Horse Racing
Tian Ji -- The Horse Racing Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Jav ...
随机推荐
- 【转载】epoll与select/poll的区别总结
因为这道题目经常被问到.干脆总结一下,免得遗漏了. 参考文章:http://www.cnblogs.com/qiaoconglovelife/p/5735936.html 1 本质上都是同步I/O 三 ...
- 2003-07-16T01:24:32Z这是什么时间格式
这是标准的XML Schema的"日期型数据格式”. T是代表后面跟着“时间”.Z代表0时区,或者叫UTC统一时间. 世界的每个地区都有自己的本地时间,在Internet及无线电通信时,时间 ...
- hadoop生态系统学习之路(十)MR将结果输出到hbase
之前讲了MR将结果输出到hdfs.hive.db,今天再给大家分享一下,怎样将结果输出到hbase. 首先,提一句,笔者在hadoop集群运行此MR的时候报了一个错误.是一个jar包的缘故,这个错误是 ...
- QC ALM 11创建域、项目和用户
一旦HP-ALM安装,我们仅仅能继续创建域.项目和用户使用后的ALM工作.以下是步骤来创建项目.域和用户. 一.创建域 1.对于创建域,第一步是进入站点管理员页面.开展QC使用URL - ...
- OpenCV2马拉松第13圈——模版匹配
收入囊中 在http://blog.csdn.net/abcd1992719g/article/details/25505315这里,我们已经学习了怎样利用反向投影和meanshift算法来在图像中查 ...
- myeclipse配置hadoop开发环境
1.安装Hadoop开发插件 hadoop安装包contrib/目录下有个插件hadoop-0.20.2-eclipse-plugin.jar,拷贝到myeclipse根目录下/dropins目录下. ...
- 借助ltp 逐步程序化实现规则库 文本生成引擎基于规则库和业务词库 去生成文本
[哪个地方做什么的哪家靠谱?地名词库行业.业务词库]苏州做网络推广的公司哪家靠谱?苏州镭射机维修哪家最专业?昆山做账的公司哪家比较好广州称重灌装机生产厂家哪家口碑比较好 [含有专家知识]郑州律师哪个好 ...
- [MAC] Load Crypto.Cipher.ARC4 Failed, Use Pure Python Instead.
MAC启动GoAgent,出现Load Crypto.Cipher.ARC4 Failed, Use Pure Python Instead. 解决方法:为Python安装pycrypto,可通过Py ...
- HDU1024 Max Sum Plus Plus —— DP + 滚动数组
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1024 Max Sum Plus Plus Time Limit: 2000/1000 MS ...
- POJ - 1330 Nearest Common Ancestors(dfs+ST在线算法|LCA倍增法)
1.输入树中的节点数N,输入树中的N-1条边.最后输入2个点,输出它们的最近公共祖先. 2.裸的最近公共祖先. 3. dfs+ST在线算法: /* LCA(POJ 1330) 在线算法 DFS+ST ...