[C++]Yellow Cards - GYM - 102348A(Practice *) - CodeForces
1 Problem Description
Problem
The final match of the Berland Football Cup has been held recently. The referee has shown n yellow cards throughout the match. At the beginning of the match there were a1 players in the first team and a2 players in the second team. The rules of sending players off the game are a bit different in Berland football. If a player from the first team receives k1 yellow cards throughout the match, he can no longer participate in the match — he’s sent off. And if a player from the second team receives k2 yellow cards, he’s sent off. After a player leaves the match, he can no longer receive any yellow cards. Each of n yellow cards was shown to exactly one player. Even if all players from one team (or even from both teams) leave the match, the game still continues. The referee has lost his records on who has received each yellow card. Help him to determine the minimum and the maximum number of players that could have been thrown out of the game.Input
The first line contains one integer a1 (1 ≤ a1 ≤ 1 000) — the number of players in the first team.The second line contains one integer a2 (1 ≤ a2 ≤ 1 000) — the number of players in the second team.The third line contains one integer k1 (1 ≤ k1 ≤ 1 000) — the maximum number of yellow cards a player from the first team can receive (after receiving that many yellow cards, he leaves the game).The fourth line contains one integer k2 (1 ≤ k2 ≤ 1 000) — the maximum number of yellow cards a player from the second team can receive (after receiving that many yellow cards, he leaves the game).The fifth line contains one integer n (1 ≤ n ≤ a1 · k1 + a2 · k2) — the number of yellow cards that have been shown during the match.Output
Print two integers — the minimum and the maximum number of players that could have been thrown out of the game.Examples
- Note
In the first example it could be possible that no player left the game, so the first number in the output is 0. The maximum possible number of players that could have been forced to leave the game is 4 — one player from the first team, and three players from the second.
In the second example the maximum possible number of yellow cards has been shown (3 · 6 + 1 · 7 = 25),so in any case all players were sent of
2 Problem Analysis
3 Code
/*
Yellow Cards - GYM - 102348 - Problem:A - 2019-09-29
[Problem Description] https://codeforces.com/gym/102348/problem/A
[Contest Material] https://codeforces.com/gym/102348/attachments/download/9362/statements.pdf
[Contest Information]
[Name] Southern and Volga Russia Qualifier 2019-2020 (GYM)
[Start] Sep/17/2019 00:00UTC+8
[Length] 04:00 (Hour)
[Other] Final standings / Prepared by BledDest Official ICPC Contest Northeastern Europe Region Russia, Saratov, 2019-2020 Statements: in English, in Russian
*/
#include<stdio.h>
#include<iostream>
using namespace std;
int min(int a1, int a2, int k1, int k2, int n){
int total = a1*(k1-1) + a2*(k2-1);
if(n <= total){
return 0;
} else {
return (n - total);
}
}
int max(int a1, int a2, int k1, int k2, int n){
int minTeamOfYellowCardsNum[2];
minTeamOfYellowCardsNum[0] = k1<k2?a1:a2;
minTeamOfYellowCardsNum[1] = k1<k2?k1:k2;
int temp1 = minTeamOfYellowCardsNum[0]*minTeamOfYellowCardsNum[1];
int temp2 = a1*k1 + a2*k2;
//printf("Amin*Kmin: %d\n", temp1);
//printf("A1*K1+A2*K2: %d\n", temp2);
if(n <= temp1){
return n/minTeamOfYellowCardsNum[1];// n < temp1
} else {
//printf("n/minTeamOfYellowCardsNum[1]: %d\n", n/minTeamOfYellowCardsNum[1]);
//printf("n: %d | Amin*Kmin(temp2): %d\n",n, temp2);
int maxTeamOfYellowCardsNum[2];
maxTeamOfYellowCardsNum[0] = k1>k2?a1:a2;
maxTeamOfYellowCardsNum[1] = k1>k2?k1:k2;
return minTeamOfYellowCardsNum[0] + ( ( n - temp1 )/maxTeamOfYellowCardsNum[1]);
}
}
int main(){
int a1,a2;
int k1,k2;
int n;
scanf("%d\n%d\n%d\n%d\n%d", &a1, &a2, &k1, &k2, &n);
//printf("%d\n%d\n%d\n%d\n%d\n", a1, a2, k1, k2, n);//test output
printf("%d\n", min(a1, a2, k1, k2, n));
printf("%d", max(a1, a2, k1, k2, n));
return 0;
}
Congratulations~
4 Problem Related Information
- [Problem Description]
- [Contest Material]
- [Contest Information]
- [Name] Southern and Volga Russia Qualifier 2019-2020 (GYM)
- [Start] Sep/17/2019 00:00UTC+8
- [Length] 04:00 (Hour)
- [Other Information]
- Final standings
- Prepared by BledDest Official ICPC Contest Northeastern Europe Region Russia, Saratov, 2019-2020 Statements: in English, in Russian
5 Recommend Documents
- 1 Codeforces游玩攻略 - About CodeForces - 知乎
- 2 在玩acm的大佬眼中codeforces这个平台怎么样? - Author:hzwer - 北京大学(计算机视觉) - About CodeForces - 知乎
- 3 在玩acm的大佬眼中codeforces这个平台怎么样? - Author:ccsu cat - About CodeForces - 知乎
- 4 洛谷
- 5 CodeForces
[C++]Yellow Cards - GYM - 102348A(Practice *) - CodeForces的更多相关文章
- Codeforces Round #585 (Div. 2) A. Yellow Cards(数学)
链接: https://codeforces.com/contest/1215/problem/A 题意: The final match of the Berland Football Cup ha ...
- A. Yellow Cards ( Codeforces Round #585 (Div. 2) 思维水题
---恢复内容开始--- output standard output The final match of the Berland Football Cup has been held recent ...
- 【Yellow Cards CodeForces - 1215A 】【贪心】
该题难点在于求最小的离开数,最大的没什么好说的,关键是求最小的. 可以这样去想,最小的离开数就是每个人获得的牌数等于他所能接受的最大牌数-1,这样就可以直接比较m=a1(k1-1)+a2(k2-1)与 ...
- Game of Cards Gym - 101128G (SG函数)
Problem G: Game of Cards \[ Time Limit: 1 s \quad Memory Limit: 256 MiB \] 题意 题意就是给出\(n\)堆扑克牌,然后给出一个 ...
- CodeForces 471C MUH and House of Cards
MUH and House of Cards Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & % ...
- Codeforces Round #384 (Div. 2) E. Vladik and cards 状压dp
E. Vladik and cards 题目链接 http://codeforces.com/contest/743/problem/E 题面 Vladik was bored on his way ...
- Gym100947E || codeforces 559c 组合数取模
E - Qwerty78 Trip Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u S ...
- Codeforces Round #281 (Div. 2)
题目链接:http://codeforces.com/contest/493 A. Vasya and Football Vasya has started watching football gam ...
- CodeForces 512B(区间dp)
D - Fox And Jumping Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64 ...
随机推荐
- Java并发包--LinkedBlockQueue
转载请注明出处:http://www.cnblogs.com/skywang12345/p/3503458.html LinkedBlockingQueue介绍 LinkedBlockingQueue ...
- 一篇文章教你如何部署.NET Core WPF应用,你还在等什么?
DevExpress广泛应用于ECM企业内容管理. 成本管控.进程监督.生产调度,在企业/政务信息化管理中占据一席重要之地.通过DevExpress WPF Controls,您能创建有着强大互动功能 ...
- border-width
border-width 语法: border-width:<line-width>{1,4} <line-width> = <length> | thin | m ...
- [Luogu] 矩阵加速(数列)
题面:https://www.luogu.org/problemnew/show/P1939 题解:https://www.zybuluo.com/wsndy-xx/note/1153810
- c实现队列
使用链表实现队列的入队和出队 #include <iostream> #include <stdio.h> #include <string.h> #include ...
- HTML基础要点归纳
一.开发环境 常用的HTML编辑器有Sublime Text.Hbuild.Dreamweare.以及vs code.pycharm等都可以.我目前在用的就是Sublime text3和Hbuild两 ...
- mysql报错码code=exited,status=2的解决方案
由于电脑死机,导致MySQL无法重启. 解决方案看官方文档,设置完后重启失败,再把innodb_force_recovery = 1去掉就可以了 https://dev.mysql.com/doc/r ...
- c++问题集合
1.对于程序未运行和运行后的代码段到底存储什么? 2.编写程序时为什么先申请变量后使用? 3.malloc本质到底分配了什么?谁赋给的? 4.程序在系统上是怎么运行起来的? 5.当我们双击一个程序运行 ...
- c#简单的SQLHelp
public abstract class SQLHelper { //只读的静态数据库连接字符串 //需添加引用System.Configuration; public static readonl ...
- react-native 打包apk 更新js和常见问题
1.打包发布 a.在工程根目录执行如下命令 打包js资源文件 react-native bundle --platform android --dev false --entry-file index ...