当前位置: 首页 > article >正文

[NOI1998] 免费的馅饼(三维偏序转二维偏序)

https://www.luogu.com.cn/problem/P7302

接完 i i i 能去接 j j j 的充要条件是什么?

  1. t i ≤ t j t_i\le t_j titj
  2. ∣ p i − p j ∣ ≤ 2 ( t j − t i ) |p_i-p_j|\le 2(t_j-t_i) pipj2(tjti)

绝对值的套路就是拆掉

  1. p i + 2 t i ≤ p j + 2 t j p_i+2t_i\le p_j+2t_j pi+2tipj+2tj
  2. 2 t i − p i ≤ 2 t j − p j 2t_i-p_i\le 2t_j-p_j 2tipi2tjpj

此时是一个三维偏序问题,我们可以直接cdq。但我们考虑把 2 , 3 2,3 2,3 式相加:

4 t i ≤ 4 t j 4t_i\le 4t_j 4ti4tj,发现 1 1 1 条件满足了。变成二维偏序问题

#include<bits/stdc++.h>
using namespace std;
#ifdef LOCAL
 #define debug(...) fprintf(stdout, ##__VA_ARGS__)
 #define debag(...) fprintf(stderr, ##__VA_ARGS__)
#else
 #define debug(...) void(0)
 #define debag(...) void(0)
#endif
#define int long long
inline int read(){int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;
ch=getchar();}while(ch>='0'&&ch<='9'){x=(x<<1)+
(x<<3)+(ch^48);ch=getchar();}return x*f;}
#define Z(x) (x)*(x)
#define pb push_back
#define fi first
#define se second
//#define M
//#define mo
#define N 200010
struct node {
	int a, b, w; 
}a[N];
int n, m, i, j, k, T;
int b[N], t, p, w, ans; 

bool cmp(node x, node y) {
	if(x.a == y.a) return x.b < y.b; 
	return x.a < y.a; 
}

struct Binary_tree {
	int cnt[N]; 
	void add(int x, int k) {
		while(x < N) cnt[x] = max(cnt[x], k), x += x & -x; 
	}
	int qry(int x) {
		int ans = 0; 
		while(x) ans = max(ans, cnt[x]), x -= x & -x; 
		return ans; 
	}
}Bin;

signed main()
{
	#ifdef LOCAL
	  freopen("in.txt", "r", stdin);
	  freopen("out.txt", "w", stdout);
	#endif
//	srand(time(NULL));
//	T = read();
//	while(T--) {
//
//	}
	n = read(); n = read(); 
	for(i = 1; i <= n; ++i) {
		t = 2 * read(); p = read(); w = read(); 
		a[i].a = t + p; a[i].b = t - p; a[i].w = w; //a[i].t = read();  
		b[i] = t - p; 
		debug("[%lld %lld] ===> (%lld %lld)\n", t, p, a[i].a, a[i].b); 
	}
	sort(a + 1, a + n + 1, cmp); 
	sort(b + 1, b + n + 1); 
	for(i = 1; i <= n; ++i) a[i].b = lower_bound(b + 1, b + n + 1, a[i].b) - b; 
	for(i = 1; i <= n; ++i) {
		debug("%lld %lld | %lld\n", a[i].a, a[i].b, a[i].w); 
		k = Bin.qry(a[i].b) + a[i].w; 
		Bin.add(a[i].b, k); ans = max(ans, k); 
	}
	printf("%lld", ans); 
	return 0; 
}


http://www.kler.cn/a/291695.html

相关文章:

  • 开源项目低代码表单设计器FcDesigner获取表单的层级结构与组件数据
  • PG-DERN 解读:少样本学习、 双视角编码器、 关系图学习网络
  • 帧中继原理与配置
  • 【流量分析】常见webshell流量分析
  • MySQL的游标和While循环的详细对比
  • 了解 Solon MVC 的参数注入规则
  • 【python爬虫】超越Selenium的自动化爬虫神器--DrissionPage语法解析与应用实战
  • C++:控制电脑状态控制
  • WPF 手撸插件 七 日志记录(二)
  • Unity(2022.3.41LTS) - UI详细介绍-Scrollbar(滚动条)
  • 【华为】测试工程师面试题汇总,你可知道华为的高薪技术岗有多香~
  • 中国航天科工笔试25考什么?如何通过人才测评|附真题库面试攻略
  • 布隆过滤器和布谷鸟过滤器
  • 设计模式 | 单例模式
  • 修改jupyter notebook 默认浏览器(不动配置文件,改系统默认浏览器)
  • Python基础语法(17多线程线程锁单例模式)
  • JS中【普通函数中的this】vs【箭头函数中的this】
  • 【Python控制台小游戏】剑与魔法
  • P3631 [APIO2011] 方格染色
  • 深度学习速通系列:Bert模型vs大型语言模型(LLM)
  • 【前端面试】采用react前后,浏览器-解析渲染UI的变化
  • 解决jupyter notebook启动需要密码的问题
  • Zabbix_Proxy自动化安装脚本
  • 五分钟搭建微信机器人保姆级教程
  • SSG页面加上了 revalidate,是不是就变成了 ISG?
  • WebRTC协议下的视频汇聚融合技术:EasyCVR视频技术构建高效视频交互体验