P4169 [Violet]天使玩偶/SJY摆棋子

求离 \((x,y)\) 最近点的距离 距离的定义是 \(|x1-x2|+|y1-y2|\)

直接cdq 4次 考虑左上右上左下右下就可以了…略微卡常数…

#include <bits/stdc++.h>

#define ls(x) ch[x][0]
#define rs(x) ch[x][1]
#define rep(i , j , k) for(int i = j ; i <= k ; i ++)
#define Rep(i , j , k) for(int i = j ; i >= k ; i --) using namespace std ;
using ll = long long ;
using pii = pair <int , int> ;
using vii = vector <int> ;
#define int long long
auto ot = [&]() { cerr << "ATS TXDY" << '\n' ; int ATS_nantf_txdy = true ; } ;
auto _ios = [&]() { ios :: sync_with_stdio(false) ; cin.tie(nullptr) ; cout.tie(nullptr) ; } ; namespace stO_ATS_Orz {
template < class T > void cmax(T & x , T y) { if(x < y) x = y ; }
template < class T > void cmin(T & x , T y) { if(x > y) x = y ; }
template < class T > void abs(T x) { if(x < 0) x = -x ; }
int n , q , opt , x , y , len ;
const int N = 1e7 + 10 ;
const int INF = 2e7 + 10 ;
struct Node {
int x , y , type , id , ans ;
} a[N] , b[N] , tem[N] ;
struct BIT {
int c[N] ;
int low(int x) { return x & -x ; }
void upd(int x , int y) {
for( ; x <= len ; x += low(x)) cmax(c[x] , y) ;
}
int qry(int x) {
int ans = 0 ;
for( ; x ; x ^= low(x)) cmax(ans , c[x]) ;
return ans ? ans : -INF ;
}
void clear(int x) {
for( ; c[x] ; x += low(x)) c[x] = 0 ;
}
} t ;
void cdq(int l , int r) {
if(l == r) { return ; }
int mid = l + r >> 1 ;
cdq(l , mid) ; cdq(mid + 1 , r) ;
int t1 = l , t2 = mid + 1 , k = l ;
while(t2 <= r) {
while(t1 <= mid && b[t1].x <= b[t2].x){
if(b[t1].type == 1) t.upd(b[t1].y , b[t1].x + b[t1].y) ;
tem[k ++] = b[t1 ++] ;
}
if(b[t2].type == 2) cmin(a[b[t2].id].ans , b[t2].x + b[t2].y - t.qry(b[t2].y)) ;
tem[k ++] = b[t2 ++] ;
}
for(int i = l ; i <= t1 - 1 ; i ++)
if(b[i].type == 1) t.clear(b[i].y) ;
while(t1 <= mid) tem[k ++] = b[t1 ++] ;
for(int i = l ; i <= r ; i ++) b[i] = tem[i] ;
}
void solve(int rx , int ry) {
for(int i = 1 ; i <= n + q ; i ++) {
b[i] = a[i] ;
if(rx) b[i].x = len - b[i].x ;
if(ry) b[i].y = len - b[i].y ;
}
cdq(1 , n + q) ;
}
void main() {
cin >> n >> q ;
for(int i = 1 ; i <= n ; i ++) {
int x , y ; cin >> x >> y ; ++ x ; ++ y ;
a[i] = { x , y , 1 , i } ;
cmax(len , max(x , y)) ;
}
for(int i = n + 1 ; i <= n + q ; i ++) {
int opt , x , y ; cin >> opt >> x >> y ; ++ x ; ++ y ;
a[i] = { x , y , opt , i , INF } ;
cmax(len , max(x , y)) ;
}
++ len ;
solve(0 , 0) ; solve(0 , 1) ; solve(1 , 0) ; solve(1 , 1) ;
for(int i = n + 1 ; i <= n + q ; i ++)
if(a[i].type == 2) cout << a[i].ans << '\n' ;
}
}
signed main() {
_ios() ; ot() ;
return stO_ATS_Orz :: main() , 0 ;
}

最新文章

  1. jbpm的学习 出处http://blog.csdn.net/hxirui/article/details/1221911
  2. Cocos2d-x 3.2 学习笔记(十)Joystick 搖杆控件
  3. Ms sql pivot unpivot
  4. 想使用 MongoDB ,你应该了解这8个方面!
  5. 关于c语言变量的内存分布测试程序
  6. angularLoad(用以异步加载js文件)
  7. Beta预备会议
  8. Postman代码测试工具如何用?
  9. input实现上传
  10. Git的分支管理
  11. js工具库
  12. XXS level7
  13. 解决python3.5无法导入cv2.so的问题
  14. Waf-Bypass-Learning
  15. mysql5.6修改字符编码,ERR:Illegal mix of collations for operation &#39;concat&#39;
  16. Man&#39;s Best Friend: The Science Behind the Dog and Human Relationship
  17. Elasticsearch5.2.0部署过程的坑
  18. Sublime Text自定义插入当前时间的插件
  19. Python入门基础学习 三
  20. 王者荣耀交流协会 - 第6次Scrum会议

热门文章

  1. 珠峰-6-node
  2. 图解css3学习笔记
  3. C++中的public、protected和private
  4. Java自学-多线程 启动一个线程
  5. 实际开发常用的jquey事件类型,并运用到图片相册
  6. 微信小程序如何下载超过大小限制(10M)的视频?(苹果用户仔细看,安卓用户快速看)
  7. Android中实现一个简单的逐帧动画(附代码下载)
  8. Escape(反思与总结)
  9. wifite硬核破解WiFi密码
  10. MySQL 8 升级数据库