UVALive 7147 World Cup
题目大意:n个队伍参加比赛,有m个队伍晋级,n个队伍有n-1场比赛,每两个队伍之间都有一场比赛。一场比赛赢的得a分,输的得c分,平局得b分,问没有晋级的队伍最高分和晋级的队伍最低分
分析:
1.没有晋级的队伍最高分
将队伍分为两堆,分别为m+1,n-m-1;令第m+1个队伍就是没晋级分数最高的队伍
第m+1个人与第二堆里面的队伍的n-m-1场比赛中得分要么每场都赢,要么每场都平局
即第m+1个人的得分: (n-m-1)*max(a, b);
贪心的让第一堆的分数高,要使第m+1个队伍就是没晋级分数最高的队伍,有两种可能
(1)第一堆m场比赛中所有队伍中每个队伍赢得场数和输的场数基本相同
即第m+1个人得分 : m/2*a+m/2*c,即m/2*(a+c);
(2)第一堆m场比赛中所有队伍都平局
即第m+1个人得分: m/2*b+m/2*b,即m/2*(b+b);
与第一堆的比赛得分取以上两场比赛的最大值
即:max(m/2*(a+c),m/2*(b+b));
第一堆的m场比赛有可能是奇数场也有可能是偶数场,如果是奇数场那么第m+1个人的得分还得加上最后一场的得分,第一堆的最后一场比赛有可能输也有可能平局(不能赢,如果赢了那这个队就有可能比前m-1个队伍分高,就应该晋级),所以得分为max(b, c);
最终第m+1个人的得分为:
x = (n-m-1)*max(a, b)+max(m/2*a+m/2*c,m/2*b+m/2*b)
如果m为奇数x+= max(b, c);否则为x;
2.晋级的队伍最低分
将队伍分为两堆,分别为m-1,n-m+1;令第m个队伍就是晋级分数最低的队伍
第m个人与第一堆里面的队伍的m-1场比赛中得分要么每场都输,要么每场都平局
即第m个人的得分: (m-1)*min(c, b);
贪心的让第二堆的分数低,要使第m个队伍就是晋级分数最低的队伍,有两种可能
(1)第二堆n-m场比赛中所有队伍中每个队伍赢得场数和输的场数基本相同
即第m个人得分 : (n-m)/2*a+(n-m)/2*c,即(n-m)/2*(a+c);
(2)第一堆n-m场比赛中所有队伍都平局
即第m个人得分: (n-m)/2*b+(n-m)/2*b,即(n-m)/2*(b+b);
与第一堆的比赛得分取以上两场比赛的最小值
即:min((n-m)/2*(a+c),(n-m)/2*(b+b));
第二堆的n-m场比赛有可能是奇数场也有可能是偶数场,如果是奇数场那么第m个人的得分还得加上最后一场的得分,第一堆的最后一场比赛有可能赢也有可能平局(不能输,如果输的话,那该队得的分数就比第二堆其他队的分数低就不能晋级了),所以得分为min(b, a);
最终第m个人的得分为:
x = (m-1)*min(c, b)+min((n-m)/2*(a+c),(n-m)/2*(b+b))
如果n-m为奇数x+= min(b, a);否则为x;
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<algorithm> using namespace std; typedef long long ll; int main()
{
int t;
ll n, m, a, b, c, x, y;
int p = ;
scanf("%d", &t);
while(t--)
{
p++;
x = y = ;
scanf("%lld%lld", &n, &m);
scanf("%lld%lld%lld", &a, &b, &c);
if(a < c)
swap(a, c);
x += (n - m - ) * max(a, b);
x += max(m / *(a + c), m/*(b + b));
if(m % != )
x += max(b, c);
y += (m - ) * min(b, c);
y += min((n - m) / * (a + c), (n - m) / *(b + b));
if((n - m) % != )
y += min(a, b);
printf("Case #%d: %lld %lld\n", p, x, y);
}
return ;
}
UVALive 7147 World Cup的更多相关文章
- UVALive 7147 World Cup(数学+贪心)(2014 Asia Shanghai Regional Contest)
题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=6 ...
- ACM学习历程—UVALive 7147 World Cup(分类讨论 && 贪心)
题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_ ...
- UVALive 7275 Dice Cup (水题)
Dice Cup 题目链接: http://acm.hust.edu.cn/vjudge/contest/127406#problem/D Description In many table-top ...
- Gym 101194L / UVALive 7908 - World Cup - [三进制状压暴力枚举][2016 EC-Final Problem L]
题目链接: http://codeforces.com/gym/101194/attachments https://icpcarchive.ecs.baylor.edu/index.php?opti ...
- UVALive - 7147 (数学)
题目链接 题意 n只队伍,两两之间会进行比赛,赢平输都有相应得分,所有比赛结束后,前m名可以晋级.问最大的不能晋级分数为多少,以及最小的能晋级的分数. 分析 智商题...按照要求来贪心1.没有晋级的队 ...
- UVA 1394 And Then There Was One / Gym 101415A And Then There Was One / UVAlive 3882 And Then There Was One / POJ 3517 And Then There Was One / Aizu 1275 And Then There Was One (动态规划,思维题)
UVA 1394 And Then There Was One / Gym 101415A And Then There Was One / UVAlive 3882 And Then There W ...
- UVALive - 4108 SKYLINE[线段树]
UVALive - 4108 SKYLINE Time Limit: 3000MS 64bit IO Format: %lld & %llu Submit Status uDebug ...
- UVALive - 3942 Remember the Word[树状数组]
UVALive - 3942 Remember the Word A potentiometer, or potmeter for short, is an electronic device wit ...
- UVALive - 3942 Remember the Word[Trie DP]
UVALive - 3942 Remember the Word Neal is very curious about combinatorial problems, and now here com ...
随机推荐
- tarjan总结
先说一下割点跟割边吧. 割桥就是如果一个连通图里删除这条边之后,这个图会变成两个连通图,那么这条边就称之为割桥. 这是割桥的代码,里面呆着lca求法. 割点和割桥的就是用一个时间戳和回到祖先确定. 用 ...
- 漫游Kafka设计篇之数据持久化
Kafka大量依赖文件系统去存储和缓存消息.对于硬盘有个传统的观念是硬盘总是很慢,这使很多人怀疑基于文件系统的架构能否提供优异的性能.实际上硬盘的快慢完全取决于使用它的方式.设计良好的硬盘架构可以和内 ...
- UVa 11090 Going in Cycle!!【Bellman_Ford】
题意:给出n个点m条边的加权有向图,求平均值最小的回路 自己想的是用DFS找环(真是too young),在比较找到各个环的平均权值,可是代码实现不了,觉得又不太对 后来看书= =好巧妙的办法, 使用 ...
- wordpress plugins collection
1/ simple page ordering 4.8星 wordpress的plugins唯一的好处就是命名简单易懂,这款插件从名称就可以看出来,用来对page页面排序的.只需要在后台page中拖拽 ...
- Bitset位图
位图(bitmap)就是用每一位来存放某种状态,适合于大规模数据但是数据状态又不是很多的情况下,通常来判断数据是否存在.位图的常见应用有两种: 1.存放大规模数据,例如腾讯的面试题,给40亿个unsi ...
- BZOJ 1984 月下“毛景树”
我觉得我要把BZOJ上的链剖写完了吧.... #include<iostream> #include<cstdio> #include<cstring> #incl ...
- 约束优化方法之拉格朗日乘子法与KKT条件
引言 本篇文章将详解带有约束条件的最优化问题,约束条件分为等式约束与不等式约束,对于等式约束的优化问题,可以直接应用拉格朗日乘子法去求取最优值:对于含有不等式约束的优化问题,可以转化为在满足 KKT ...
- 最大熵模型 Maximum Entropy Model
熵的概念在统计学习与机器学习中真是很重要,熵的介绍在这里:信息熵 Information Theory .今天的主题是最大熵模型(Maximum Entropy Model,以下简称MaxEnt),M ...
- KVM虚拟化技术简介
kernel-based Virtual Machine的简称,是一个开源的系统虚拟化模块,自Linux 2.6.20之后集成在Linux的各个主要发行版本中.它使用Linux自身的调度器进行管理,所 ...
- Shell教程4-Shell替换
如果表达式中包含特殊字符,Shell 将会进行替换.例如,在双引号中使用变量就是一种替换,转义字符也是一种替换. 举个例子: 复制纯文本新窗口 #!/bin/bash a=10 echo -e & ...