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

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

题目大意是就是n个人进行两两的比赛,胜一局得A分,平局B分,败局C分。

然后取前m名入围,求入围的人最小的可能分数以及被淘汰的人的最大的可能分数。

这题首先可以想到的是胜A负C和胜C负A的情况是一模一样的。

所以可以先考虑让A大C小。

然后开始分情况讨论:

(1)B最小

1·这种情况下全部平局的话,能让入围的人分数最小。

2·然后需要考虑被淘汰的人的最大的可能分数:

必然将这些人分成m+1+n-m-1

由于要让这个’1’的分数尽可能大,自然考虑让n-m-1个人全部负场淘汰。

这样前面m+1个人都先得到a*(n-m-1)分。

然后需要让这个’1’尽可能大的话,首先他可以和m其中一半的人打胜场,和另一半的人打负场,这比打平局合算。然后这一半的人再胜另一半的人,这种情况所有人分数平衡。

此时又得到m/2*(a+c)分。

最后如果m是奇数,那么最后一场打负场。

这样做,因为’1’最多只能胜m个人里面一半的人,否则他肯定不会是最后一名。

所以中间打一半胜一半负,而且最后m%2那一局不能胜。

此外c>b,所以考虑m%2那场负。

(2)B最大

1·这种情况下全部平局的话,能让被淘汰的人的分数最大。

2·然后需要考虑围的人最小的可能分数;

必然将这些人分成m-1+1+n-m

由于要让这个’1’的分数尽可能小,自然考虑让m-1个人全部胜场入围。

这样前面n-m+1个人都先得到c*(m-1)分。

然后需要让这个’1’尽可能小的话,首先他可以和n-m其中一半的人打胜场,和另一半的人打负场,这比打平局分数少。

此时又得到(n-m)/2*(a+c)分。

最后如果n-m是奇数,那么最后一场打胜场。

这样做,因为’1’最多只能负m个人里面一半的人,否则他肯定不会是第一名。

所以中间打一半胜一半负,而且最后(n-m)%2那一局不能负。

此外a<b,所以考虑(n-m)%2那场胜。

(3)剩余情况中2*b < a+c的:

为什么考虑这两者的关系,因为上面的讨论已经发现了微妙的联系。

1·考虑围的人最小的可能分数;

必然m-1+1+n-m

然后让前面的m-1个人都胜场入围,那么必然’1’首先需要败m-1场。

然后他需要胜过至少(n-m)里面的一半人,这种情况下由于一开始的2*b < a+c,他选择平局分数更小。

自然最后如果多一场选择平局,而不选择胜局。

2·考虑被淘汰的人的最大的可能分数:

自然需要先胜(n-m-1)个人,因为他们全部负场。

然后他跟前面的人打一半胜一半负,因为2*b < a+c。

最后多的一场m%2打平局,否则他将胜过一半人。

(4)最后一种情况和(3)类似了。

代码:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <set>
#include <map>
#include <vector>
#include <string>
#include <queue>
#define LL long long
#define MOD 1000000007

using namespace std;

int n, m, a, b, c;
LL mi, ma;

void input()
{
    scanf("%d%d", &n, &m);
    scanf("%d%d%d", &a, &b, &c);
    if (a < c) swap(a, c);
}

void work()
{
    if (b < a && b < c)
    {
        mi = (LL)b*(n-1);
        ma = (LL)a*(n-m-1);
        ma += (LL)m/2*(a+c);
        ma += (LL)c*(m%2);//
        return;
    }
    if (b > a && b > c)
    {
        ma = (LL)b*(n-1);
        mi = (LL)c*(m-1);
        mi += ((LL)n-m)/2*(a+c);
        mi += (LL)a*((n-m)%2);//
        return;
    }
    if (2*b < a+c)
    {
        mi = (LL)c*(m-1);
        mi += ((LL)n-m)*b;

        ma = (LL)a*(n-m-1);
        ma += (LL)m/2*(a+c);
        ma += (LL)b*(m%2);//
        return;
    }
    else
    {
        mi = (LL)c*(m-1);
        mi += ((LL)n-m)/2*(a+c);
        mi += (LL)b*((n-m)%2);//

        ma = (LL)a*(n-m-1);
        ma += (LL)m*b;
        return;
    }
}

int main()
{
    //freopen("test.in", "r", stdin);
    int T;
    scanf("%d", &T);
    for (int times = 1; times <= T; ++times)
    {
        input();
        work();
        printf("Case #%d: ", times);
        printf("%lld %lld\n", ma, mi);
    }
    return 0;
}

时间: 2024-11-02 07:08:11

ACM学习历程—UVALive 7147 World Cup(分类讨论 && 贪心)的相关文章

ACM学习历程—HDU 4726 Kia&#39;s Calculation( 贪心&amp;&amp;计数排序)

DescriptionDoctor Ghee is teaching Kia how to calculate the sum of two integers. But Kia is so careless and alway forget to carry a number when the sum of two digits exceeds 9. For example, when she calculates 4567+5789, she will get 9246, and for 12

ACM学习历程—FZU 2144 Shooting Game(计算几何 &amp;&amp; 贪心 &amp;&amp; 排序)

Description Fat brother and Maze are playing a kind of special (hentai) game in the playground. (Maybe it’s the OOXX game which decrypted in the last problem, who knows.) But as they don’t like using repellent while playing this kind of special (hent

ACM学习历程—HDU 5023 A Corrupt Mayor&#39;s Performance Art(广州赛区网赛)(线段树)

Problem Description Corrupt governors always find ways to get dirty money. Paint something, then sell the worthless painting at a high price to someone who wants to bribe him/her on an auction, this seemed a safe way for mayor X to make money. Becaus

ACM学习历程—UESTC 1226 Huatuo&#39;s Medicine(数学)(2015CCPC L)

题目链接:http://acm.uestc.edu.cn/#/problem/show/1226 题目就是构造一个对称的串,除了中间的那个只有1个,其余的两边都是对称的两个,自然答案就是2*n-1. 代码: #include <iostream> #include <cstdio> #include <cstdlib> #include <cmath> #include <cstring> #include <algorithm> #

LA UVaLive 6862 Triples (数学+分类讨论)

题意:给定一个n和m,问你x^j + y^j = z^j 的数量有多少个,其中0 <= x <= y <= z <= m, j = 2, 3, 4, ... n. 析:是一个数学题加分类讨论.首先对 x进行分类讨论. 当 0 = x 时,只要 y = z,就行,那么就有(m+1) *  (n-1) 个,因为 y 可能从0取到m ,j 可以从2取到 n. 当 0 != x 时,那么只要一个勾股定理能构成,只要幂大于2,就一下没解,所以我们把第一种中拿出j = 2时,的特殊情况,特殊考

ACM学习历程—BestCoder Round #75

1001:King's Cake(数论) http://acm.hdu.edu.cn/showproblem.php?pid=5640 这题有点辗转相除的意思.基本没有什么坑点. 代码: #include <iostream> #include <cstdio> #include <cstdlib> #include <cmath> #include <cstring> #include <algorithm> #include &l

ACM学习历程—HDU5585 Numbers(数论 || 大数)(BestCoder Round #64 (div.2) 1001)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5585 题目大意就是求大数是否能被2,3,5整除. 我直接上了Java大数,不过可以对末尾来判断2和5,对所有位的和来判断3. 代码就不粘了.

ACM学习历程—HDU5587 Array(数学 &amp;&amp; 二分 &amp;&amp; 记忆化 || 数位DP)(BestCoder Round #64 (div.2) 1003)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5587 题目大意就是初始有一个1,然后每次操作都是先在序列后面添加一个0,然后把原序列添加到0后面,然后从0到末尾,每一个都加上1. 例如:a0, a1, a2 => a0, a1, a2, 1, a0+1, a1+1, a2+1 题解中是这么说的:“ 其实Ai为i二进制中1的个数.每次变化A{k+2^i}=A{k}+1,(k<2^?i??)不产生进位,二进制1的个数加1.然后数位dp统计前m个数二

ACM学习历程—HDU 3915 Game(Nim博弈 &amp;&amp; xor高斯消元)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3915 题目大意是给了n个堆,然后去掉一些堆,使得先手变成必败局势. 首先这是个Nim博弈,必败局势是所有xor和为0. 那么自然变成了n个数里面取出一些数,使得xor和为0,求取法数. 首先由xor高斯消元得到一组向量基,但是这些向量基是无法表示0的. 所以要表示0,必须有若干0来表示,所以n-row就是消元结束后0的个数,那么2^(n-row)就是能组成0的种数. 对n==row特判一下. 代码: