[The Preliminary Contest for ICPC Asia Shanghai 2019] B-Light bulbs(差分+思维)
前言
最近有很多算不上事的事,搞得有点心烦,补题难免就很水,没怎么搞,自我检讨一番~~
说实话网络赛题目的质量还是挺高的,题目都设计的挺好的,很值得学习。这场比赛那会只有我们大二的在做,其他人去参加$CCF$认证去了,赛后这题搞出来了,跟$lsq$一顿解释,说这个其实也不难,她就说但是你看就这个地方卡了多少人,那会才两百多人过了。的确,有的题目还是很考思维的。(个人感觉很久没写博客,写这篇还是有点混乱的,有些博主把这题加上离散化的标签,想起来好像是有那么点道理)
题意
有 $n $个灯泡,初始全部为关闭状态,有$ m $个操作,每次操作给出 $[l,r]$,让你将区间 $[l,r] $的灯泡反转,问最终有多少灯泡是亮着的。$[ link ]$
其中有 $T $组数据,$T \leq 1000, n \leq 10^{6}, m \leq 1000$
分析
当时刚开始做的时候,那会因为刚好看了两天的差分,就觉得这题很对我胃口,肯定能搞出来,然而事实给了我一巴掌,$TLE$
我当时就想不通了明明是$O(n)$的做法,后来仔细一看,复杂度$T*n$,$10^{9}$多半是不行了,毕竟每次都还要把差分数组初始化为0。开始用到$for$循环初始化,也超时了,就换成了$memset$。后来$zym$提醒说$memset$很花时间,我就想多拿几个数组记录一下,把原来的状态的还原回去,结果开了四个数组,空间超了$\cdots $,可能出题人也想到了有人会像我这样做(网上有博主好像用这种方法做出来了,具体的还没有看)这我就没有办法了,才不得不放弃。
$0(n)$的做法是利用差分每次只需要修改两个端点,最后求前缀和,是奇数就代表是灯是亮着的。(自认为是差分的精髓所在)这题需要强调的是对于每个端点修改的是一整个区间(以这个端点为最左边直到最右边的边界),每组$l,r$,$l$和$r+1$所对应的区间都会加1,两者操作是一样的,所以对于所有要修改的区间的修改顺序是无所谓的,因此我把这些代表区间的端点进行排序,$a_{1}$ $to$ $a_{2}$, $a_{3} $ $to$ $ a_{4} ,\cdots , a_{k-1}$ $to$ $a_{k}$两两相减加起来就能得到答案,在草稿纸上画一画想一想应该就知道了,并不需要把前缀和都求一遍。
Code
#include <bits/stdc++.h>
using namespace std;
const int maxn = 1e6+5;
int n, m;
int a[maxn]; int main()
{
int t;
scanf("%d", &t);
for (int kase = 1; kase <= t; kase++) {
scanf("%d%d", &n, &m);
int k = 0;
for (int i = 1; i <= m; i++) {
int l, r;
scanf("%d%d", &l, &r);
a[++k] = l;
a[++k] = r+1;
}
sort(a+1, a+1+k); int ans = 0;
for (int i = 1; i <= k; i+=2) ans += a[i+1]-a[i];
printf("Case #%d: %d\n", kase, ans);
}
}
参考文章:
https://www.cnblogs.com/violet-acmer/p/11523777.html
[The Preliminary Contest for ICPC Asia Shanghai 2019] B-Light bulbs(差分+思维)的更多相关文章
- The Preliminary Contest for ICPC Asia Shanghai 2019 B. Light bulbs
题目:https://nanti.jisuanke.com/t/41399 思路:差分数组 区间内操作次数为奇数次则灯为打开状态 #include<bits/stdc++.h> using ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 B Light bulbs (离散的差分)
复杂度分析,询问一千次,区间长1e6,O(1e9)超时. 那么我们知道对于差分来说,没必要一个一个求,只需要知道区间长就可以了,所以我们定义结构体差分节点,一个头结点,一个尾节点. 这样tail.lo ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 C Triple(FFT+暴力)
The Preliminary Contest for ICPC Asia Shanghai 2019 C Triple(FFT+暴力) 传送门:https://nanti.jisuanke.com/ ...
- The Preliminary Contest for ICPC Asia Shanghai 2019
传送门 B. Light bulbs 题意: 起初\(n\)个位置状态为\(0\),\(m\)次操作,每次操作更换区间状态:\(0\)到\(1\),\(1\)到\(0\). 共有\(T,T\leq 1 ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 C. Triple
[传送门] FFT第三题! 其实就是要求有多少三元组满足两短边之和大于等于第三边. 考虑容斥,就是枚举最长边,另外两个数组里有多少对边之和比它小,然后就是 $n^3$ 减去这个答案. 当 $n \le ...
- 01背包方案数(变种题)Stone game--The Preliminary Contest for ICPC Asia Shanghai 2019
题意:https://nanti.jisuanke.com/t/41420 给你n个石子的重量,要求满足(Sum<=2*sum<=Sum+min)的方案数,min是你手里的最小值. 思路: ...
- 给定进制下1-n每一位数的共享(Digit sum)The Preliminary Contest for ICPC Asia Shanghai 2019
题意:https://nanti.jisuanke.com/t/41422 对每一位进行找循环节规律就行了. #define IOS ios_base::sync_with_stdio(0); cin ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 A. Lightning Routing I
传送门 因为某些原因,所以我就去学了 $LCT$ 维护直径, $LCT$ 维护直径我上一个博客讲得很详细了:传送门 这里维护虚儿子用的是 $multiset$ ,没写可删堆 #include<i ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 L. Digit sum
题目:https://nanti.jisuanke.com/t/41422 思路:预处理 #include<bits/stdc++.h> using namespace std; ][]= ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 J. Stone game
题目:https://nanti.jisuanke.com/t/41420 思路:当a(a∈S′)为最小值 如果Sum(S′)−a≤Sum(S−S′)成立 那么(∀t∈S′,Sum(S′)−t≤Sum ...
随机推荐
- 真的,kafka 入门看这一篇准没错!
什么是 Kafka Kafka 是一个分布式流式平台,它有三个关键能力 订阅发布记录流,它类似于企业中的消息队列 或 企业消息传递系统 以容错的方式存储记录流 实时记录流 Kafka 的应用 作为消息 ...
- Flutter 布局类组件:层叠布局(Stack和Positioned)
前言 层叠布局,即子组件可以根据距父容器四个角的位置来确定自身的位置.绝对定位运行子组件堆叠起来,即按照代码中声明的顺序. Flutter中使用Stack和Positioned这两个组件来配合实现绝对 ...
- 求素数个数的优化-LeetCode204
问题 计数质数 统计所有小于非负整数 n 的质数的数量. 示例: 输入: 10 输出: 4 解释: 小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 . 第一种解法容易想到但是会 超时 ...
- RAC上的DG搭建
准备工作 修改rman_backup这个文件的所有者和所属组,修改为oracle用户的oinstall组的文件 #chown –R oracle:oinstall /rman_backup/ 主库和备 ...
- 二本学生拿到腾讯大厂offer的成长记录
本人迈莫,是在20年以春招实习生的身份进入鹅厂,经过重重波折,最终成为鹅仔一份子.接下来我会以我亲生经历为例,分享一下普通大学的学生也是可以进去大厂,拭目以待!!! 初入大学 惨遭毒打 时间倒回到17 ...
- Python赋值、浅复制和深复制
Python赋值.浅复制和深复制 首先我们需要知道赋值和浅复制的区别: 赋值和浅复制的区别 赋值,当一个对象赋值给另一个新的变量时,赋的其实是该对象在栈中的地址,该地址指向堆中的数据.即赋值后,两 ...
- MySQL 中的临时表
在使用 explain 解析一个 sql 时,有时我们会发现在 extra 列上显示 using temporary ,这表示这条语句用到了临时表,那么临时表究竟是什么?它又会对 sql 的性能产生什 ...
- python(paramiko模块的简单使用)
#通过paramiko模块连接主机运行bash命令 import paramiko hostname = '192.168.88.31' port = 22 username = 'root' pas ...
- k8s之PV、PVC、StorageClass详解
导读 上一篇写了共享存储的概述以及一个简单的案例演示.这一篇就写一下PV和PVC. PV是对底层网络共享存储的抽象,将共享存储定义为一种"资源",比如Node也是容器应用可以消费的 ...
- windows2012-2016亲测安装mysql8.0
先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 不要手动创建Data文件夹和my.ini文件, cmd命令窗口进入bin目录,如果已经做了环境变量那随意在哪里打开. mysqld ...