题目链接:http://codeforces.com/contest/807/problem/D

题意:对于动态计分的 Codeforces Round ,已知每题的 score 是根据 Round 参加人数和该题过题人数计算,两者之比结合上图得出该题的分数。某人在该题的得分为 score*(1−t/250) 其中 t 表示通过该题的时间。

已知参加该场比赛的所有参加者的过题情况(包括 Vasya 和 Petya),问如何通过增加新的参赛者(尽量少),使得 Vasya 的最终得分高于 Petya。

题解:首先预算一下最多需要多少人,3000*4/12=10000,最多不超过10000人。

然后就枚举一遍0~10000,需要注意的是几种情况

       if(T[1].a[j] == -1) {

rate[j] = 1.0 * sum[j] / (n + i);

}

else {

if(T[1].a[j] > T[2].a[j] && T[2].a[j] != -1) {

rate[j] = 1.0 * (sum[j] + i) / (n + i);

}

else {

rate[j] = 1.0 * sum[j] / (n + i);

}

}

这些情况考虑了就行了。

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#define inf 0X3f3f3f3f
using namespace std;
struct TnT {
int a[6];
}T[200];
int main() {
int n;
double rate[6];
int sum[6];
memset(sum , 0 , sizeof(sum));
scanf("%d" , &n);
for(int i = 1 ; i <= n ; i++) {
for(int j = 1 ; j <= 5 ; j++) {
scanf("%d" , &T[i].a[j]);
if(T[i].a[j] >= 0) {
sum[j]++;
}
}
}
int flag = 0;
for(int i = 1 ; i <= 5 ; i++) {
if(T[2].a[i] > T[1].a[i] || (T[2].a[i] == -1 && T[1].a[i] != -1)) {
flag = 1;
break;
}
}
if(!flag) {
printf("-1\n");
}
else {
int ans = -1;
for(int i = 0 ; i <= 10000 ; i++) {
double sum1 = 0 , sum2 = 0;
for(int j = 1 ; j <= 5 ; j++) {
if(T[1].a[j] == -1) {
rate[j] = 1.0 * sum[j] / (n + i);
}
else {
if(T[1].a[j] > T[2].a[j] && T[2].a[j] != -1) {
rate[j] = 1.0 * (sum[j] + i) / (n + i);
}
else {
rate[j] = 1.0 * sum[j] / (n + i);
}
}
}
for(int j = 1 ; j <= 5 ; j++) {
if(rate[j] <= 1.0 && rate[j] > 1.0 / 2) {
if(T[1].a[j] >= 0) sum1 += 1.0 * 500 * (1.0 - 1.0 * T[1].a[j] / 250);
if(T[2].a[j] >= 0) sum2 += 1.0 * 500 * (1.0 - 1.0 * T[2].a[j] / 250);
}
if(rate[j] <= 1.0 / 2 && rate[j] > 1.0 / 4) {
if(T[1].a[j] >= 0) sum1 += 1.0 * 1000 * (1.0 - 1.0 * T[1].a[j] / 250);
if(T[2].a[j] >= 0) sum2 += 1.0 * 1000 * (1.0 - 1.0 * T[2].a[j] / 250);
}
if(rate[j] <= 1.0 / 4 && rate[j] > 1.0 / 8) {
if(T[1].a[j] >= 0) sum1 += 1.0 * 1500 * (1.0 - 1.0 * T[1].a[j] / 250);
if(T[2].a[j] >= 0) sum2 += 1.0 * 1500 * (1.0 - 1.0 * T[2].a[j] / 250);
}
if(rate[j] <= 1.0 / 8 && rate[j] > 1.0 / 16) {
if(T[1].a[j] >= 0) sum1 += 1.0 * 2000 * (1.0 - 1.0 * T[1].a[j] / 250);
if(T[2].a[j] >= 0) sum2 += 1.0 * 2000 * (1.0 - 1.0 * T[2].a[j] / 250);
}
if(rate[j] <= 1.0 / 16 && rate[j] > 1.0 / 32) {
if(T[1].a[j] >= 0) sum1 += 1.0 * 2500 * (1.0 - 1.0 * T[1].a[j] / 250);
if(T[2].a[j] >= 0) sum2 += 1.0 * 2500 * (1.0 - 1.0 * T[2].a[j] / 250);
}
if(rate[j] <= 1.0 / 32 && rate[j] > 0.0) {
if(T[1].a[j] >= 0) sum1 += 1.0 * 3000 * (1.0 - 1.0 * T[1].a[j] / 250);
if(T[2].a[j] >= 0) sum2 += 1.0 * 3000 * (1.0 - 1.0 * T[2].a[j] / 250);
}
}
if(sum1 > sum2) {
ans = i;
break;
}
}
printf("%d\n" , ans);
}
return 0;
}

最新文章

  1. iOS CoreData技术学习资源汇总
  2. 往Android SDCard中读写入数据
  3. 【转】SQL Server 2012 配置AlwaysOn(三)
  4. jquery方法的参数解读
  5. Xcode中实现ARC和MRC混编
  6. 机器学习算法实现(R&amp;Python code)
  7. SecureCRT 使用
  8. Spark算子--filter
  9. 【转载】详解 $_SERVER 函数中QUERY_STRING和REQUEST_URI区别
  10. 使用WebStorm报错 Namespace &#39;v-bind&#39; is not bound
  11. python异常处理机制
  12. Asp.net中web.config配置文件详解(一)
  13. ROS知识(15)----Actionlib的使用(一)
  14. linux shell 脚本攻略学习8---md5校验,sort排序,uniq命令详解
  15. mongodb 搭建主从服务器
  16. 福大软工1816 &#183;软工之404NoteFound团队选题报告
  17. kill -9 a postgres process
  18. IDEA 提示找不到 javax 等 tomcat 的相关包
  19. jenkins+Publish Over SSH 提示:Transferred 0 file(s)
  20. TCP学习(一)

热门文章

  1. 使用hexo中遇到的问题
  2. 基于SpringBoot从零构建博客网站 - 集成editor.md开发发布文章功能
  3. Java课堂 动手动脑5
  4. 【Java例题】3.5 级数之和
  5. 【Java例题】1.3给朋友的贺卡
  6. Of efficiency and methodology
  7. 在vue项目中引入阿里图标库小记
  8. Logback配置文件这么写,TPS提高10倍
  9. 纯前端下载pdf链接文件,而不是打开预览的解决方案
  10. 【win10主机】访问virtualbox上【32位winXP系统虚拟机】上启动的项目