当前位置: 首页 > article >正文

CF254B Jury Size

在这里插入图片描述

题目翻译

CF254B 评审团人数

题目描述

在2013年,伯兰德州立大学的出题者需要为 n n n 场奥林匹克竞赛准备题目。我们假定这些奥林匹克竞赛用从1到 n n n 的连续整数编号。对于每一场奥林匹克竞赛,我们知道需要多少评审团成员参与其题目准备工作,以及准备该竞赛题目所需的时间。具体来说,第 i i i 场奥林匹克竞赛需要 p i p_{i} pi 个人花费 t i t_{i} ti 天来准备,并且准备工作应该是一个连续的时间段,且恰好要在竞赛开始的前一天结束。在竞赛当天,已经准备好该竞赛的评审团成员就不再为这场竞赛工作了。

例如,如果一场奥林匹克竞赛在12月9日举行,且准备工作需要7个人花费6天时间,那么所有7名评审团成员将从12月3日到12月8日为这场奥林匹克竞赛的题目工作(评审团成员在12月9日不会为这场奥林匹克竞赛的题目工作,也就是说,他们中的一些人可以开始为其他某场奥林匹克竞赛准备题目)。而如果一场奥林匹克竞赛在11月3日举行,且需要5天的准备时间,评审团成员将从10月29日到11月2日进行工作。

为了避免评审团负担过重,引入了以下规则:一名评审团成员不能在同一天为不同的奥林匹克竞赛的题目工作。编写一个程序,确定评审团中最少需要多少人,才能按时准备好所有的奥林匹克竞赛。

输入格式

第一行包含整数 n n n —— 2013年奥林匹克竞赛的数量( 1 ≤ n ≤ 100 1 \leq n \leq 100 1n100)。接下来的 n n n 行,每行包含四个整数 m i m_{i} mi d i d_{i} di p i p_{i} pi t i t_{i} ti —— 奥林匹克竞赛的月份和日期(没有前导零)、所需的评审团成员数量以及准备第 i i i 场奥林匹克竞赛所需的时间( 1 ≤ m i ≤ 12 1 \leq m_{i} \leq 12 1mi12 d i ≥ 1 d_{i} \geq 1 di1 1 ≤ p i , t i ≤ 100 1 \leq p_{i}, t_{i} \leq 100 1pi,ti100), d i d_{i} di 不超过月份 m i m_{i} mi 的天数。奥林匹克竞赛的给出顺序是任意的。几场奥林匹克竞赛可能在同一天举行。

在解题时使用现代(公历)日历。注意所有日期都是在2013年。这一年不是闰年,所以2月有28天。请注意,某些奥林匹克竞赛的准备工作可能会在2012年开始。

输出格式

输出一个整数 —— 评审团的最小人数。

输入输出样例 #1

输入 #1

2
5 23 1 2
3 13 2 3

输出 #1

2

输入输出样例 #2

输入 #2

3
12 9 2 1
12 8 1 3
12 8 2 2

输出 #2

3

输入输出样例 #3

输入 #3

1
1 10 1 13

输出 #3

1

题解

就是统计一下每一天需要多少人,用暴力求最大值就行了

Code

#include <bits/stdc++.h>

using namespace std;

int n;
int f[1000];
int a[20] = {0, 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334};

int main()
{
//	freopen("10.in", "r", stdin);
//	freopen("10.out", "w", stdout);
	cin >> n;
	for (int i = 1; i <= n; i++)
	{
		int a1, b, c, d;
		cin >> a1 >> b >> c >> d;
		d--;
		int l = a[a1] + b - d + 100;
		int r = a[a1] + b + 100;
		for (int j = l; j <= r; j++)
		{
			f[j] += c;
		}
	}
	int ans = 0;
	for (int i = 100; i <= 456; i++)
	{
		ans = max(ans, f[i]);
	}
	cout << ans << endl;
}

http://www.kler.cn/a/610258.html

相关文章:

  • 备赛蓝桥杯之第十六届模拟赛2期职业院校组第六题:菜谱教程
  • ngx_http_core_root
  • ngx_http_core_error_page
  • 回退N帧协议(GBN)有差错情况下的详细流程
  • Unity2D 五子棋 + Photon联网双人对战
  • Android系统的安全问题 - Linux的能力模型(Capability)和 SELinux 的区别
  • Checksum方法实现
  • DDR4、DDR5、固态硬盘(SSD)和机械硬盘(HDD)在连续读/写、随机读/写性能的对比分析
  • Softmax 回归 + 损失函数 + 图片分类数据集
  • 重生细胞全符文获取攻略
  • LangChain4j(1):初识LangChain4j
  • 3. 轴指令(omron 机器自动化控制器)——>MC_GearInPos
  • Open CASCADE学习|根据给定的点集拟合一条B样条曲线
  • MATLAB导入Excel数据
  • 【论文精读-图像恢复】 All-In-One Image Restoration for Unknown Corruption
  • Kotlin 协程官方文档知识汇总(二)
  • MySQL 和 Redis 数据一致性解决方案
  • 字节码生成技术
  • springboot启动事件CommandLineRunner使用
  • HarmonyOS Next~鸿蒙应用框架开发实战:Ability Kit与Accessibility Kit深度解析