题面

不知道大佬们怎么想的,反正我看到这种区间包含性质的并且score只和包含的区间与询问区间挂钩的题,马上就想到了扫描线23333

虽然革命方向无比正确,但却因为SB错误交了5次才 A。

WA第一发:考虑到我们扫描线的话是要坐标离散化的,然而这种做法是默认正方形内至少有一个点。可所有点权都是负值就尴尬了,这个时候需要找一个空点来把答案替代成0。虽然我考虑到了这种情况,但是第一次找空点的时候不仅写麻烦了(我是用 num[i]+1<num[i+1] 来判断两个坐标之间是否有空隙),而且漏了最大坐标后面的。。。。不过如果你观察题面描述仔细的话,你是会发现输出要求的 坐标是可以 >1e9的,这就是这题的坑比之处,答案<0就可以直接输出 0 \n 1000000001 1000000001 1000000001 1000000001 了。。

WA第二发:我开的vector的下标是离散化之后的坐标,显然是要开两倍空间的,忘开了。。。

WA第三发:又发现线段树的下标也是离散化之后的坐标,显然空间是要开n的八倍的,wori

WA第四发:操作线段树的时候有个 long long 写成int了,gan

#include<bits/stdc++.h>
#define ll long long
using namespace std;
#define lc (o<<1)
#define mid (l+r>>1)
#define rc ((o<<1)|1)
#define pb push_back
const int N=500005; inline int read(){
int x=0,f=1; char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-1;
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';
return x*f;
} /*
注意数组空间啊!
虽然只有n个点,不过离散化之后最多涉及 2n 个坐标值
g[i]是用来存右端点在i的点的链表,所以空间开2n
因为线段树的下标是离散后的坐标次序,所以空间要开 8n 而不是 4n
*/ vector<int> g[N*2];
int n,a[N],b[N],num[N*2],ky,c[N],L,R,pos[N*8],w,le=1,ri,P;
ll ans=-1e18,mx[N*8],ad[N*8],now; inline void maintain(int o){
pos[o]=mx[rc]>mx[lc]?pos[rc]:pos[lc];
mx[o]=max(mx[lc],mx[rc]);
} inline void Get(int o,ll w){
ad[o]+=w,mx[o]+=w;
} inline void pushdown(int o){
if(ad[o]) Get(lc,ad[o]),Get(rc,ad[o]),ad[o]=0;
} void build(int o,int l,int r){
if(l==r){ pos[o]=mx[o]=num[l]; return;}
build(lc,l,mid),build(rc,mid+1,r);
maintain(o);
} void update(int o,int l,int r){
if(l>=le&&r<=ri){ Get(o,w); return;} pushdown(o); if(le<=mid) update(lc,l,mid);
if(ri>mid) update(rc,mid+1,r); maintain(o);
} void query(int o,int l,int r){
if(l>=le&&r<=ri){ if(mx[o]>mx[P]) P=o; return;}
// P在query后是最大的线段树上的节点,需要转换到具体的数轴上的点
pushdown(o); if(le<=mid) query(lc,l,mid);
if(ri>mid) query(rc,mid+1,r);
} inline void solve(){
build(1,1,ky),mx[0]=-1e18;
for(int i=1;i<=ky;i++){
for(int j:g[i]) ri=a[j],w=c[j],update(1,1,ky);
P=0,ri=i,query(1,1,ky);
if(mx[P]-num[i]>ans) ans=mx[P]-num[i],R=num[i],L=pos[P];
}
} int main(){
n=read(),num[0]=-1;
for(int i=1;i<=n;i++){
a[i]=read(),b[i]=read(),c[i]=read();
num[++ky]=a[i],num[++ky]=b[i];
if(a[i]>b[i]) swap(a[i],b[i]);
} sort(num+1,num+ky+1),ky=unique(num+1,num+ky+1)-num-1;
for(int i=1;i<=n;i++){
a[i]=lower_bound(num+1,num+ky+1,a[i])-num;
b[i]=lower_bound(num+1,num+ky+1,b[i])-num;
g[b[i]].pb(i);
} solve();
if(ans<=0) ans=0,L=R=1e9+1; cout<<ans<<endl;
printf("%d %d %d %d\n",L,L,R,R); return 0;
} /*
Σc[] + j - i
*/

  

Codeforces 1221 F Choose a Square的更多相关文章

  1. Codeforces 959 F. Mahmoud and Ehab and yet another xor task

    \(>Codeforces\space959 F. Mahmoud\ and\ Ehab\ and\ yet\ another\ xor\ task<\) 题目大意 : 给出一个长度为 \ ...

  2. Codeforces 835 F. Roads in the Kingdom

    \(>Codeforces\space835 F. Roads in the Kingdom<\) 题目大意 : 给你一棵 \(n\) 个点构成的树基环树,你需要删掉一条环边,使其变成一颗 ...

  3. Codeforces 731 F. Video Cards(前缀和)

    Codeforces 731 F. Video Cards 题目大意:给一组数,从中选一个数作lead,要求其他所有数减少为其倍数,再求和.问所求和的最大值. 思路:统计每个数字出现的个数,再做前缀和 ...

  4. Codeforces 1187 F - Expected Square Beauty

    F - Expected Square Beauty 思路:https://codeforces.com/blog/entry/68111 代码: #pragma GCC optimize(2) #p ...

  5. Codeforces 1221F. Choose a Square

    传送门 对于某个点 $(x,y)$ ,不妨设 $x<y$ 因为如果 $x>y$ 直接按 $y=x$ 对称一下即可 当且仅当正方形左下角 $(a,a)$ 满足 $a<=x$,右上角 $ ...

  6. CodeForces 135 B. Rectangle and Square(判断正方形和 矩形)

    题目:http://codeforces.com/problemset/problem/135/B 题意:给8个点 判断能否用 4个点构成正方形,另外4个点构成 矩形. 输出 第一行是正方形 ,第二行 ...

  7. Codeforces 715A & 716C Plus and Square Root【数学规律】 (Codeforces Round #372 (Div. 2))

    C. Plus and Square Root time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  8. Codeforces 474 F. Ant colony

    线段树求某一段的GCD..... F. Ant colony time limit per test 1 second memory limit per test 256 megabytes inpu ...

  9. Codeforces Round #423 B. Black Square

    题目网址:http://codeforces.com/contest/828/problem/B 题目: Polycarp has a checkered sheet of paper of size ...

随机推荐

  1. 在Yii2中集成Markdown编辑器

    安装命令: composer require ijackua/yii2-lepture-markdown-editor-widget:dev-master 可能会遇到的问题 如果在下载依赖包的过程中出 ...

  2. 『Python Web框架之Django』第几节: AJAX

    一. AJAX简介 AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步的Javascript和XML”.即使用Javascript语言与服务器进行异步交互, ...

  3. ARM协处理器CP15寄存器详解

    改自:https://blog.csdn.net/gameit/article/details/13169405 *C2描述的不对,bit[31-14]才是TTB,不是所有的bit去存储ttb.很明显 ...

  4. Apache2.4+Tomcat7.0+php5.5整合配置详解

    在上一篇的基础上,继续添加php的配置 一.首先下载php5.5 首先下载php5.5,到官网下载http://www.php.net/downloads.php,参考http://www.cnblo ...

  5. SQL Server 2017命令创建新账户(test-user),并分配数据库权限

    -- 1. 创建登录账号USE [master];GOCREATE LOGIN [test-user] WITH PASSWORD = 'xysu7SZ193SNX6E{{HxubPE3}vr',DE ...

  6. kong命令(四)upstream

    介绍 upstream 就是一个虚拟的服务.可用于配置多个target目标服务时实现负载均衡的效果. 注意:service的host指的就是upstream的name. 同时upstream提供了一个 ...

  7. mac OS下 安装MySQL 5.7

    Mac OS X 下 TAR.GZ 方式安装 MySQL 5.7 与 MySQL 5.6 相比, 5.7 版本在安装时有两处不同: 1:初始化方式改变, 从scripts/mysql_install_ ...

  8. umi model 注册

    model 分两类,一是全局 model,二是页面 model.全局 model 存于 /src/models/ 目录,所有页面都可引用:页面 model 不能被其他页面所引用. 规则如下: src/ ...

  9. matplotlib基本函数

    数据分析 matlab Numpy + scipy + pandas +matplotlib 数据计算 +科学应用+数据清洗+数据可视化 1 Numpy概述 1 基于c语言的python接口的数值算法 ...

  10. smart_ptr之shared_ptr

    智能指针的概念 c++11标准和boost都提供了智能指针的功能.智能指针是普通指针的封装,智能指针是一个对象,对象里面包含了原生指针.可以使用智能指针对象的get()方法可获得封装在里面的原生指针. ...