ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

[CF527D]Clique Problem 题解

2022-06-19 22:33:42  阅读:172  来源: 互联网

标签:QAQ int 题解 线段 ans ge lst CF527D Problem


传送门QAQ

Preface

终究是思维能力不够啊QAQ

学到了学到了。

Analysis

首先观察到连边具有双向性,考虑直接拆开绝对值,即 \(x_i - x_j\ge w_i+w_j\)

很显然,珂以把相同下标的放到一块维护,即 \(x_i-w_i\ge x_j+w_j\)

这玩意没有任何性质,我看了半天也没找出任何用巧妙的暴力或线段树求的方法。

这个时候就需要跳脱出原有的思维了,一个典型的套路是观察下这个东西像啥。

发现,将 \([x_i-w_i,x_i+w_i]\) 设为第 \(i\) 条线段的边界,那么上面这个式子的要求就是求出最多的不互相覆盖的线段个数。

这个东西珂以用贪心解决,详见 [P1803]凌乱的yyy / 线段覆盖

时间复杂度 \(O(N\log N)\),瓶颈在排序上。

Code

超级超级短awa

#include <bits/stdc++.h>
using namespace std;
const int maxn = 2e5 + 5;
struct node {
	int l,r;
	node() {
		l = r = 0;
	}
}a[maxn];
int n;
int main() {
	scanf("%d",&n);
	for(int i = 1;i <= n;++ i) {
		int x,y;
		scanf("%d%d",&x,&y);
		a[i].l = x - y;
		a[i].r = x + y;
	}
	sort(a + 1 , a + 1 + n , [](node x,node y){return x.r == y.r ? x.l > y.l : x.r < y.r;});
	int lst = -1e9,ans = 0;
	for(int i = 1;i <= n;++ i) {
		if(a[i].l >= lst) {
			++ ans;
			lst = a[i].r;
		}
	}
	printf("%d",ans);
	return 0;
}

完结撒花✿✿ヽ(°▽°)ノ✿

标签:QAQ,int,题解,线段,ans,ge,lst,CF527D,Problem
来源: https://www.cnblogs.com/663B/p/16391677.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有