Light bulbs

题目链接

毒瘤题
又卡时间又卡空间
思路
显然有一个不考虑时限的做法。对于每次操作 [ l , r ] [l,r] [l,r],我们都可以把区间 [ 0 , n 1 ] [0,n-1] [0,n1]中的下标 l , r + 1 l,r+1 l,r+1标记加一,然后扫一般前缀和就可以得到应有的答案。
但是显然这个做***T的,复杂度为 O ( T n ) O(T*n) O(Tn)
我们观察发现,对于 0 n 1 0-(n-1) 0n1的数字我们只需要关注m次操作的端点,所以可以采取离散化。
AC代码

#include <bits/stdc++.h>

using namespace std;
typedef long long ll;
const int maxn = 1e6 + 5;
int tot[2005];
struct node{
    int Case;
    int time;
}flag[maxn];
int main(){
    int t, kase = 0;
    scanf("%d", &t);
    while(t--){
    ++kase;
// map<int, int>flag;
	int n, m, cnt = 0;
	scanf("%d%d", &n, &m);
	for(int i = 1; i <= m; i++){
		int l, r;
		scanf("%d%d", &l, &r);
		tot[++cnt] = l;
		tot[++cnt] = r + 1;
		if(flag[l].Case != kase){
			flag[l].time = 1;
			flag[l].Case = kase;
		}
		else{
			flag[l].time++;
		}
		if(flag[r + 1].Case != kase){
			flag[r + 1].time = 1;
			flag[r + 1].Case = kase;
		}
		else{
			flag[r + 1].time++;
		}
	}
	sort(tot + 1, tot + cnt + 1);
	int Num = unique(tot + 1, tot + cnt + 1) - (tot + 1);
	//for(int i = 1; i <= m; i++)
	int sum = 0;
	int ans = 0;
	for(int i = 1; i <= Num; i++){
		sum = sum + flag[tot[i]].time;
		if(sum % 2){
			if(i != Num)
				ans += tot[i + 1] - tot[i];
			else
				ans++;
		}
	}
	printf("Case #%d: %d\n", kase, ans);
    }
    return 0;
}

全部评论

相关推荐

03-08 18:11
门头沟学院 Java
Java抽象小篮子:海投就完事了,简历没什么问题,最大问题是学历
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
4609次浏览 48人参与
# 离家近房租贵VS离家远但房租低,怎么选 #
16917次浏览 137人参与
# 米连集团26产品管培生项目 #
7423次浏览 228人参与
# 沪漂/北漂你觉得哪个更苦? #
1646次浏览 41人参与
# 你的实习产出是真实的还是包装的? #
3261次浏览 54人参与
# 春招至今,你的战绩如何? #
16231次浏览 147人参与
# 巨人网络春招 #
11559次浏览 230人参与
# HR最不可信的一句话是__ #
1118次浏览 33人参与
# AI面会问哪些问题? #
976次浏览 24人参与
# 你做过最难的笔试是哪家公司 #
1319次浏览 23人参与
# AI时代,哪个岗位还有“活路” #
2956次浏览 53人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152954次浏览 889人参与
# 简历第一个项目做什么 #
32209次浏览 364人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
8032次浏览 43人参与
# XX请雇我工作 #
51165次浏览 171人参与
# 简历中的项目经历要怎么写? #
311176次浏览 4273人参与
# 投格力的你,拿到offer了吗? #
178395次浏览 891人参与
# 你最满意的offer薪资是哪家公司? #
77017次浏览 375人参与
# AI时代,哪些岗位最容易被淘汰 #
64881次浏览 895人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187657次浏览 1123人参与
# 你怎么看待AI面试 #
180898次浏览 1320人参与
# 正在春招的你,也参与了去年秋招吗? #
364423次浏览 2642人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务