https://icpcarchive.ecs.baylor.edu/index.phpoption=com_onlinejudge&Itemid=8&page=show_problem&problem=5159

题目大意: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的更多相关文章

  1. UVALive 7147 World Cup(数学+贪心)(2014 Asia Shanghai Regional Contest)

    题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=6 ...

  2. ACM学习历程—UVALive 7147 World Cup(分类讨论 && 贪心)

    题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_ ...

  3. UVALive 7275 Dice Cup (水题)

    Dice Cup 题目链接: http://acm.hust.edu.cn/vjudge/contest/127406#problem/D Description In many table-top ...

  4. 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 ...

  5. UVALive - 7147 (数学)

    题目链接 题意 n只队伍,两两之间会进行比赛,赢平输都有相应得分,所有比赛结束后,前m名可以晋级.问最大的不能晋级分数为多少,以及最小的能晋级的分数. 分析 智商题...按照要求来贪心1.没有晋级的队 ...

  6. 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 ...

  7. UVALive - 4108 SKYLINE[线段树]

    UVALive - 4108 SKYLINE Time Limit: 3000MS     64bit IO Format: %lld & %llu Submit Status uDebug ...

  8. UVALive - 3942 Remember the Word[树状数组]

    UVALive - 3942 Remember the Word A potentiometer, or potmeter for short, is an electronic device wit ...

  9. UVALive - 3942 Remember the Word[Trie DP]

    UVALive - 3942 Remember the Word Neal is very curious about combinatorial problems, and now here com ...

随机推荐

  1. cocoStudio UI编辑器 学习总结

    一.控件 控件基类 UIWidget:所有UI控件的基类 addChild:添加UIWidget类型的节点 addRenderer:添加CCNode类型的节点 所有UIWidget,都可以设置成触摸s ...

  2. RBAC(Role-Based Access Control,基于角色的访问控制)

    RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联.简单地说,一个用户拥有若干角色,每一个角色拥有若干权限.这样,就构造成“用户-角色- ...

  3. LeetCode——Add Two Numbers

    Question:You are given two linked lists representing two non-negative numbers. The digits are stored ...

  4. javamail模拟邮箱功能发送电子邮件-中级实战篇【新增附件发送方法】(javamail API电子邮件实例)

    引言: JavaMail jar包下载地址:http://java.sun.com/products/javamail/downloads/index.html 此篇是紧随上篇文章而封装出来的,阅读本 ...

  5. JVM内存结构——运行时数据区

    在Java虚拟机规范中将Java运行时数据划分为6种,分别为: PC寄存器(程序计数器) Java栈 堆 方法区 运行时常量池 本地方法栈 一.PC寄存器(程序计数器) PC寄存器(Program C ...

  6. MySQL与Oracle 差异比较之一数据类型

    数据类型 编号 ORACLE MYSQL 注释 1 NUMBER int / DECIMAL DECIMAL就是NUMBER(10,2)这样的结构INT就是是NUMBER(10),表示整型:MYSQL ...

  7. jQuery 实现Bootstrap Chart 图表

    很多时候我们制作报表的时候需要图表,如果你使用bootstrap开发你的网站,如果你需要使用图表,那么最简单的方法就是就是使用bootstrap 的chart.js来实现图表,下面介绍方法 1.引入c ...

  8. 利用ArcGIS Engine、VS .NET和Windows控件开发GIS应用

    Dixon 原文  用ArcGIS Engine.VS .NET和Windows控件开发GIS应用     此过程说明适合那些使用.NET建立和部署应用的开发者,它描述了使用ArcGIS控件建立和部署 ...

  9. Ajax实现搜索栏中输入时的自动提示功能

    使用 jQuery(Ajax)/PHP/MySQL实现自动完成功能 JavaScript代码: <script src="jquery-1.2.1.pack.js" type ...

  10. bjfu1299 stl使用

    题目超简单,我写解题报告是因为我的代码用了些STL,使代码很简洁. * * Author : ben */ #include <cstdio> #include <cstdlib&g ...