CF815D
模拟赛遇到的题目。
看各位大佬的做法都不是很懂,于是自己一通乱搞搞出来了。
题意
做法
为了方便叙述,我们将每个给出的三元组表示成 \((a_i,b_i,c_i)\),所选的三元组表示成\((x,y,z)\)。
首先我们考虑如果 \(c_i\) 相等(设为 \(c\))怎么做:
直接做看起来很麻烦,于是我们考虑正难则反,由算可行解数量改为算不可行解数量,并维护对于每一个 \(y\) 可选的 \(x\) ,显然对于每一个\(y\),\(x\)的选择满足单调性。
然后我们分类讨论一下 \(z\) 和 \(c_i\) 的大小关系
当 \(z \le c\) 时,对于每一个三元组,当 \(y \in [1,b_i]\) 时, \(x>p\);当 $y \in (b_i,q] \(时,\)x>a_i$。
当 \(z>c\) 时,对于每一个三元组,只需满足当 \(y \in [1,b_i]\)时,\(x>a_i\) 即可。
拿个线段树维护一下就可以了。
然后我们将这种做法拓展一下,我们先把原序列按 \(c_i\) 从大到小排序,可以轻易发现此时当 \(z \in (c_i,c_{i+1}]\) 时,每一个 \(z\) 贡献都是一样的
对于每一个区间\((c_i,c_{i+1}]\),我们考虑上面的做法来算贡献,显然对于前 \(i\) 个三元组,满足 \(z>c\) 的条件,对于后面的三元组,满足 \(z \le c\) 的条件。
且显然 \(z \le c\) 的条件是比 \(z > c\) 完全严格的,所以每次修改的时候把 \(z > c\)的条件给当前枚举到的三元组加上去就好了。
然后关于这个线段树,我们需要维护区间最大值,区间求和,这个可以自行百度解决(相信做到这道题的大佬都会)。
#include <bits/stdc++.h>
#define int long long
#define INF 2147483647
#define N 1000005
#define mkp make_pair
#define pii pair<int,int>
#define pb push_back
using namespace std;
int n,A,B,C,ans=0;
struct Y{int a,b,c;}a[N];
int cmp(Y x,Y y){return x.c>y.c;}
struct Ji_seg{
struct Tr{
int mn,tag,t,se,sum;
}tr[N<<2];
int ls(int nw){return nw*2;}
int rs(int nw){return nw*2+1;}
void change(int nw,int l,int r,int k){//对nw节点的区间进行区间取max
if(k<=tr[nw].mn)return;
if(k<tr[nw].se){
tr[nw].sum+=(k-tr[nw].mn)*tr[nw].t;
tr[nw].mn=k;tr[nw].t=max(tr[nw].t,1ll);tr[nw].tag=max(tr[nw].tag,k);
return;
}
int mid=(l+r)/2;
change(ls(nw),l,mid,k);change(rs(nw),mid+1,r,k);push_up(nw);
}
void push_down(int nw,int l,int r){
if(tr[nw].tag){
int mid=(l+r)/2;
change(ls(nw),l,mid,tr[nw].tag);
change(rs(nw),mid+1,r,tr[nw].tag);
tr[nw].tag=0;
}
}
void push_up(int nw){
tr[nw].sum=tr[ls(nw)].sum+tr[rs(nw)].sum;
if(tr[ls(nw)].mn==tr[rs(nw)].mn){
tr[nw].mn=tr[ls(nw)].mn;
tr[nw].t=tr[ls(nw)].t+tr[rs(nw)].t;
tr[nw].se=min(tr[ls(nw)].se,tr[rs(nw)].se);
return;
}
if(tr[ls(nw)].mn<tr[rs(nw)].mn){tr[nw].mn=tr[ls(nw)].mn;tr[nw].t=tr[ls(nw)].t;tr[nw].se=min(tr[ls(nw)].se,tr[rs(nw)].mn);}
else {tr[nw].mn=tr[rs(nw)].mn;tr[nw].t=tr[rs(nw)].t;tr[nw].se=min(tr[rs(nw)].se,tr[ls(nw)].mn);}
}
void build(int nw,int l,int r){
if(l==r){
tr[nw].sum=0;tr[nw].mn=0;tr[nw].se=INF;tr[nw].t=1;tr[nw].tag=0;
return;
}
int mid=(l+r)/2;
build(ls(nw),l,mid);
build(rs(nw),mid+1,r);
push_up(nw);
}
void update(int nw,int l,int r,int x,int y,int k){
if(x>y)return;
if(x<=l&&r<=y){
change(nw,l,r,k);
return;
}
int mid=(l+r)/2;push_down(nw,l,r);
if(x<=mid)update(ls(nw),l,mid,x,y,k);
if(y>mid)update(rs(nw),mid+1,r,x,y,k);
push_up(nw);
}
}T;
signed main() {
scanf("%lld %lld %lld %lld",&n,&A,&B,&C);
for(int i=1;i<=n;i++)scanf("%lld %lld %lld",&a[i].a,&a[i].b,&a[i].c);
sort(a+1,a+n+1,cmp);a[0]=Y{0,0,C};a[n+1]=Y{0,0,0};
T.build(1,1,B);
for(int i=1;i<=n;i++)T.update(1,1,B,1,a[i].b,a[i].a);
for(int i=0;i<=n;i++){
T.update(1,1,B,1,a[i].b,A);T.update(1,1,B,a[i].b+1,B,a[i].a);
ans+=(a[i].c-a[i+1].c)*(A*B-T.tr[1].sum);
}
printf("%lld\n",ans);
return 0;
}
CF815D的更多相关文章
- CF815D Karen and Cards
CF815D Karen and Cards 固定一维c,然后(a,b)看成坐标,矩形区域求交 1.Segment tree Beats! 2.改成不合法的区域就是求并,c反向枚举,区域只增不减且完全 ...
- 【CF815D】Karen and Cards 单调栈+扫描线
[CF815D]Karen and Cards 题意:一张卡片有三个属性a,b,c,其上限分别为A,B,C,现在有n张卡片,定义一张卡片能打败另一张卡片当且仅当它的至少两项属性要严格大于另一张的对应属 ...
- CF815D Karen and Cards 官方题解翻译
看到这道题,网上没有中文版的官方题解,于是就自己翻译了一遍. 不是机器翻译,是一个字一个字纯手翻译的,如果有错误欢迎指正. 比如我们有一张卡片,三个参数分别是 a1 = 4, b1 = 2, c1 = ...
- [学习笔记]Segment Tree Beats!九老师线段树
对于这样一类问题: 区间取min,区间求和. N<=100000 要求O(nlogn)级别的算法 直观体会一下,区间取min,还要维护区间和 增加的长度很不好求.... 然鹅, 从前有一个来自杭 ...
随机推荐
- SpringMVC完整版详解
1.回顾MVC 1.1什么是MVC MVC是模型(Model).视图(View).控制器(Controller)的简写,是一种软件设计规范. 是将业务逻辑.数据.显示分离的方法来组织代码. MVC主要 ...
- HTML短链接
短链接跳转方法 新建一个目录名称就是短链接字符列如:1 创建一个index.html文件里面添加代码如下 <script type="text/javascript"> ...
- 没写完。【java】IDEA-调教界面、设置语言、插件的使用
步骤: 1.官方网站:https://www.jetbrains.com/idea/ (zip)版本:https://download.jetbrains.com.cn/idea/ideaIC-202 ...
- Stringboot中@Autowired加了static就属性值就为null
//错误 @Autowired private static DepartmentDao departmentDao; @Autowired注入,将bean注入进来 @Autowired通过sprin ...
- 因势而变,因时而动,Go lang1.18入门精炼教程,由白丁入鸿儒,Go lang泛型(generic)的使用EP15
事实上,泛型才是Go lang1.18最具特色的所在,但为什么我们一定要拖到后面才去探讨泛型?类比的话,我们可以想象一下给小学一年级的学生讲王勃的千古名篇<滕王阁序>,小学生有多大的概率可 ...
- ELK技术-IK-中文分词器
1.背景 1.1 简介 ES默认的分词器对中文分词并不友好,所以一般会安装中文分词插件,以便能更好的支持中文分词检索. 本例参考文档:<一文教你掌握IK中文分词> 1.2 IK分词器 IK ...
- 在Ubuntu上安装Odoo时遇到的问题
这两天开始看<Odoo快速入门与实践 Python开发ERP指南>(刘金亮 2019年5月第1版 机械工业出版社).试着在Ubuntu上安装Odoo,遇到很多问题,通过在网上查找,都已解 ...
- 6.Ceph 基础篇 - CephFS 文件系统
文章转载自:https://mp.weixin.qq.com/s?__biz=MzI1MDgwNzQ1MQ==&mid=2247485294&idx=1&sn=e9039504 ...
- 天翼云上新增IP备案具体操作步骤
0.点击右上角的备案,进入到备案中心 1.已备案信息管理 点击左侧的已备案信息管理,右侧出现的页面中找到已备案网站信息,网站负责人后面的操作里有5个图标,点击第三个(变更接入),提交订单,进入到下一步 ...
- 不停机为虚拟机添加主机磁盘(以VMware Workstation为例)
VMware Workstation软件上安装的centos7系统,新增磁盘后使用fdisk -l命令查看不到新增的磁盘,有没有办法在不重启的情况下添加上新磁盘? 有办法 具体如下: # 查看主机总线 ...