[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 ...
随机推荐
- Python+MySQL随机试卷及答案生成程序
一.背景 本文章主要是分享如何使用Python从MySQL数据库中面抽取试题,生成的试卷每一份都不一样. 二.准备工作 1.安装Python3 下载地址:https://www.python.org/ ...
- C语言指针的大小
C语言指针的大小 今天看到一道题目是这样的,写出以下变量在32位设备上的大小(占多少个字节) 然后其中就有一些指针类型的数据,那么我们知道在C语言中指针的大小都是一样的,不管是有数据类型的还是void ...
- 【剑指 Offer】10-I.斐波那契数列
题目描述 写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项.斐波那契数列的定义如下: F(0) = 0, F(1) = 1 F(N) = F(N - 1) + F(N - ...
- 【Flutter】功能型组件之对话框详解
前言 对话框本质上也是UI布局,通常一个对话框会包含标题.内容,以及一些操作按钮,为此,Material库中提供了一些现成的对话框组件来用于快速的构建出一个完整的对话框. 接口描述 // 1. Ale ...
- LeetCode704 二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1. 示例 1: 输入: num ...
- 9. 细节见真章,Formatter注册中心的设计很讨巧
目录 本文提纲 版本约定 你好,我是A哥(YourBatman). Spring设计了org.springframework.format.Formatter格式化器接口抽象,对格式化器进行了大一统, ...
- pandas 写csv 操作
pandas 写csv 操作 def show_history(self): df = pd.DataFrame() df['Time'] = pd.Series(self.time_hist) df ...
- poj-DNA排序
描述 现在有一些长度相等的DNA串(只由ACGT四个字母组成),请将它们按照逆序对的数量多少排序. 逆序对指的是字符串A中的两个字符A[i].A[j],具有i < j 且 A[i] > A ...
- ORACLE查找占用临时表空间多的SESSION
需要使用SYS用户登录查看 /* Formatted on 2020/12/30 上午 11:17:12 (QP5 v5.163.1008.3004) */ SELECT k.inst_id &quo ...
- AQS之ReentrantReadWriteLock精讲分析上篇
1.用法 1.1 定义一个安全的list集合 public class LockDemo { ArrayList<Integer> arrayList = new ArrayList< ...