Codeforces Round 974 (Div. 3) - D题

news/2024/10/1 17:12:15

这道题题意就是你有k个工作,每个工作都有一个时间区间左边界l和右边界r,妈妈和哥哥要来看你,时长为d,题目要求求出 1.哥哥看你的这段时间工作时间段重叠最多是多少?2.妈妈看你的这段时间工作时间段重叠最少是多少?
这道题如果硬做的话可能就是线段树了(蒟蒻暂时没有想到其他的做法),但如果反正来想,不找重叠最多,而是找不重叠最少,不找重叠最少,而是找不重叠最多,这样就简单多了(大概...) 具体来说就是在来看你的这段时间d,如果重叠的工作最多,那么在这段时间的“两边”的“独立”的工作最少,反之如果重叠的工作最少,那么在这段时间的“两边”的“独立”的工作最多。除此之外,这道题还有一个非常有趣的点是对于工作时间的处理,将原本的区间形状的时间变化为点状的时间(大家可以体会一下,我不太会描述,这点我当时比较困惑,琢磨了一段时间),这样更方便进行操作,非常非常的精妙。下面放代码:

#include<bits/stdc++.h>
#define ll long long
using namespace std;void slove(){ll n, d, k;cin >> n >> d >> k;vector <ll> a(n + 1, 0), b(n + 1, 0);for(ll i = 1; i <= k; i ++){ll l, r;cin >> l >> r;l --;a[l] ++, b[r] ++;}//右边界for(ll i = 1; i <= n; i ++){b[i] += b[i - 1];}//左边界for(ll i = n - 1; i >= 0; i --){a[i] += a[i + 1];}ll mx = -1, mn = n + 1, idmx, idmn;n -= d;for(ll i = 0; i <= n; i ++){ll num = b[i] + a[i + d];// cout << num << endl;if(num > mx){mx = num;idmx = i + 1;}if(num < mn){mn = num;idmn = i + 1;}}// cout << "ans:";cout << idmn << " " << idmx << endl;return ;
}
int main(){ll t;cin >> t;while(t --){slove();}return 0;
}

对于这道题我起初的思路是用树状数组来维护,但处理的时候时间复杂度会出问题,又想到了线段树,但写起来麻烦,就没有继续进行,一直没想到什么巧妙的想法,直到看了哥哥的视频,起初也没看懂,后来恍然大悟,琢磨半天终于懂了,哥哥吴迪啊啊啊!!!
最近太摆,前几天本来说写这道题题解的,一直拖延再加上玩,就拖到了今天...好好调整吧,争取在国庆集训回归正轨

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/66840.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

CSP2024-30

A 题意:将一个圆等分为 \(K\) 分,给出其中 \(n\) 个等分点的编号,\(x_i < x_{i + 1}\)。 有向边 \(i \to j\) 存在,当且仅当 \(j\) 是距离 \(i\) 最大的点(不唯一),且与图中其他边无交点(端点不算)。 求图中最多有多少条边。\(3 \le K \le 10^9, 3 \le n \le \min(…

小白上手Arcgis—用于结合Netlogo、matlab等进行复杂网络操作

小白上手Arcgis(Netlogo复杂网络数据预处理) 1.前言废话:昨天突然想到可以写一下博客,用来记录一下自己的工作,主要是涉及复杂网络方面。情况简介:本人Arcgis小白,之前只是略微知道有这么个软件,以及知道怎么打开软件。学渣一个,而且不是学gis方向的,但由于工作需要,要…

windows10如何安装jdk8,并且配置java home环境?超详细!

前言 大家好,我是小徐啊。记得我刚学习Java的时候,我的老师第一步就是教我们如何安装jdk并且配置java环境。这应该算是学习Java的第一步吧。虽然这个安装过程对我来说已经不是非常难了,但是我知道,对于一些刚入门的小伙伴还是经常容易搞错的,所以,今天小徐就写一篇详细的…

安装小雅问题

如何卸载重装小雅、apt remove xiaoya docker stop 01ec8396b2c529819bb7c95091a88a9af6999c042bcb7ab57662837c97dca5cd docker rm 01ec8396b2c529819bb7c95091a88a9af6999c042bcb7ab57662837c97dca5cdsystemctl start cpolar 开启cplpr systemctl status cpolar

leetcode24 两两交换链表中的节点(swap-nodes-in-pairs)

### 题目描述: 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。 示例 1:输入:head = [1,2,3,4] 输出:[2,1,4,3]示例 2: 输入:head = [] 输出:[]示例 3: 输入:head = [1] 输出…

第一章:Borel测度

第1章 Borel测度 在正式讨论我们的内容之前我们先做几点说明 1.我们只讨论\(\mathbb{R}^n\) 上的测度,因此如果不作特别说明,我们均认为测度和集合为于\(\mathbb{R}^n\) 中: 2.我们不特别区分外测度和测度,因为将外测度限制在可测集上就是可测集上的测度: 3.我们默认读者已…

TypeScript在vue中的使用-----事件类型的获取

当我们要对事件定义类型。一种是通过console.log(e)来看事件的类型。另外一种是@事件名的时候,将$event写好,鼠标放上去看事件类型。再讲$event删除。 如下: 然后我们定义函数的时候就可以指定事件类型了const clickMi = (e:MouseEvent)=>{console.log(e.pageX, e.pageY…

信息学奥赛复赛复习08-CSP-J2020-03表达式前置知识点-后缀表达式、栈、字符读取

PDF文档公众号回复关键字:202410011 P1449 后缀表达式 [题目描述] 所谓后缀表达式是指这样的一个表达式:式中不再引用括号,运算符号放在两个运算对象之后,所有计算按运算符号出现的顺序,严格地由左而右新进行(不用考虑运算符的优先级) 本题中运算符仅包含 + - * / 。保证…