和去年多校的CSGO一样,用状态压缩来求Manhattan距离的最大值

然后要用线段树维护一下区间最大值

/*
k维空间给定n个点,两个操作
1 i b1 b2 .. bk : 修改第i个点的坐标
2 l r:询问[l,r]区间点最大的曼哈顿距离 先考虑不带修:
线段树维护区间2^5种状态的最大值
查询时只要求出相对的两个状态的最大值即可 关于这个贪心的证明:
首先因为绝对值,所以aij前面带的符号可能是-也可能是+,总共就是有关2^k种可能
那么考虑每种状态 S 的最大值,加上相对这种状态 (1<<k)-S 的最大值,来维护答案
其实会有很多情况是不应该存在的,比如aij是第j维最小的,那么其前面的符号就只能是-
可是当其前面的符号是+时也被考虑进去了,其实能够保证另有一个数比这种情况大
即这种情况对结果不造成影响 再来考虑待修的情况
修改pos位置的点,就要去线段树中更新和这个点有关的2^5种状态 所以还是线段树维护区间最大值的问题,可以用一个结点来维护
*/
#include<bits/stdc++.h>
using namespace std;
#define maxn 200005
int k,n,m,a[maxn][],v[maxn][<<]; #define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
struct Node{int Max,val[<<];}p[maxn<<];
void pushup(int rt){
for(int i=;i<(<<);i++)
p[rt].val[i]=max(p[rt<<].val[i],p[rt<<|].val[i]);
p[rt].Max=-0x3f3f3f3f;
for(int i=;i<(<<);i++)
p[rt].Max=max(p[rt].Max,p[rt].val[i]+p[rt].val[(<<)--i]);
}
void build(int l,int r,int rt){
if(l==r){
for(int i=;i<(<<);i++){
p[rt].val[i]=v[l][i];
// p[rt].Max=max(p[rt].Max,v[l][i]);
}
return;
}
int m=l+r>>;
build(lson);build(rson);
pushup(rt);
}
void update(int pos,int l,int r,int rt){//更新第pos个点
if(l==r){
for(int i=;i<(<<);i++)
p[rt].val[i]=v[l][i];
return;
}
int m=l+r>>;
if(pos<=m)update(pos,lson);
else update(pos,rson);
pushup(rt);
}
Node merge(Node a,Node b){
for(int i=;i<(<<);i++)
a.val[i]=max(a.val[i],b.val[i]);
for(int i=;i<(<<);i++)
a.Max=max(a.Max,a.val[i]+b.val[(<<)-i-]);
return a;
}
Node query(int L,int R,int l,int r,int rt){
if(L<=l && R>=r)
return p[rt];
int m=l+r>>;
Node res;
for(int i=;i<(<<);i++)
res.val[i]=-0x3f3f3f3f;
res.Max=-0x3f3f3f3f; if(L<=m)
res=merge(res,query(L,R,lson));
if(R>m)
res=merge(res,query(L,R,rson));
return res;
} int main(){
cin>>n>>k;
for(int i=;i<=n;i++){
for(int j=;j<k;j++)
scanf("%d",&a[i][j]); for(int S=;S<(<<);S++){
for(int j=;j<;j++)
if(S&(<<j))v[i][S]+=a[i][j];
else v[i][S]-=a[i][j];
}
} build(,n,); cin>>m;
int op,l,r,pos;
while(m--){
scanf("%d",&op);
if(op==){
scanf("%d",&pos);
for(int i=;i<k;i++)
scanf("%d",&a[pos][i]);
for(int S=;S<(<<);S++){
v[pos][S]=;
for(int j=;j<;j++)
if(S&(<<j))
v[pos][S]+=a[pos][j];
else v[pos][S]-=a[pos][j];
}
update(pos,,n,);
}
else {
scanf("%d%d",&l,&r);
Node node=query(l,r,,n,);
cout<<node.Max<<'\n';
}
}
}

线段树区间合并+k维空间的曼哈顿距离——cf1093G好题的更多相关文章

  1. Codeforces 1093G题解(线段树维护k维空间最大曼哈顿距离)

    题意是,给出n个k维空间下的点,然后q次操作,每次操作要么修改其中一个点的坐标,要么查询下标为[l,r]区间中所有点中两点的最大曼哈顿距离. 思路:参考blog:https://blog.csdn.n ...

  2. POJ 2482 Stars in Your Window (线段树区间合并+扫描线)

    这题开始一直被矩形框束缚了,想法一直都是枚举线,但是这样枚举都需要O(n^2)...但是看了别人的思路,感觉这题思想真心很好(PS:开头好浪漫的描述啊,可惜并没有什么用)  题意就是在平面上给你一些星 ...

  3. poj3667 线段树 区间合并

    //Accepted 3728 KB 1079 ms //线段树 区间合并 #include <cstdio> #include <cstring> #include < ...

  4. hdu3911 线段树 区间合并

    //Accepted 3911 750MS 9872K //线段树 区间合并 #include <cstdio> #include <cstring> #include < ...

  5. poj-3667(线段树区间合并)

    题目链接:传送门 参考文章:传送门 思路:线段树区间合并问题,每次查询到满足线段树的区间最左值,然后更新线段树. #include<iostream> #include<cstdio ...

  6. hdu-3308 LCIS (线段树区间合并)

    LCIS Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  7. hdu 3308(线段树区间合并)

    LCIS Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  8. 【bzoj2325】[ZJOI2011]道馆之战 树链剖分+线段树区间合并

    题目描述 给定一棵树,每个节点有上下两个格子,每个格子的状态为能走或不能走.m次操作,每次修改一个节点的状态,或询问:把一条路径上的所有格子拼起来形成一个宽度为2的长方形,从起点端两个格子的任意一个开 ...

  9. 【BZOJ3638】Cf172 k-Maximum Subsequence Sum 线段树区间合并(模拟费用流)

    [BZOJ3638]Cf172 k-Maximum Subsequence Sum Description 给一列数,要求支持操作: 1.修改某个数的值 2.读入l,r,k,询问在[l,r]内选不相交 ...

随机推荐

  1. Linux网络编程 了解

    IPV4 -- IP地址分类:主机号是区分主机的,网络号是区分网段的 子网掩码是对主机号进行划分子网用的 举例说明: 对 192.168.1.0网段划分4个 其子网掩码 : 拿出主机号的两个位进行划分 ...

  2. python3添加requests库

    1.资源下载 https://codeload.github.com/psf/requests/zip/master https://www.python.org/ https://files.pyt ...

  3. Redmine 和GitBlit仓库服务器整合

    运行环境: RedMine: 4.0.4 Git 仓库: Gitbilt V1.8.0 必须: Redmine 安装并可运行 Redmine运行的主机里面已经安装了 Git,因需要在命令行中运行 gi ...

  4. Java List 快速搜索对象

    比如现在有一个需求现在有一个List 里面装Student 对象 我们想找出这个List 对象里面student name=小明的对象 我想很多同学会像以前的我一样变量List 然后去比较 但是这样处 ...

  5. 移动端图片轮播效果:depth模式总结

    最近公司app改版首页增加了一处轮播图效果,但是跟普通的轮播效果不同,是类似于下图的样式,找了一些兼容移动端的插件以及jQuery源码,总结一下使用心得: 1:jquery源码:缺点是在手机端的滑动很 ...

  6. Delphi实现屏幕截图、窗口截图、指定区域截图

    Use Jpeg procedure TForm1.snapscreen(a,b,c,d:Integer); var bmpscreen:Tbitmap; jpegscreen:Tjpegimage; ...

  7. NX二次开发-UFUN工程图表格注释获取某一列的tag函数UF_TABNOT_ask_nth_column

    NX9+VS2012 #include <uf.h> #include <uf_tabnot.h> #include <NXOpen/Part.hxx> #incl ...

  8. 【Python】模拟登录上海西南某高校校园网 (jaccount)

    好久没写东西了,最近学习了一下模拟登录,以校园网为例,作一记录. 去年的时候写过一篇模拟登录的文章,用的是登录后的cookies,这种操作比较傻瓜,也不智能,不够自动化,本质还是手动登录. 这次我尝试 ...

  9. docker网络原理

    以下内容引用Docker -- 从入门到实践 当 Docker 启动时,会自动在主机上创建一个 docker0 虚拟网桥,实际上是 Linux 的一个 bridge,可以理解为一个软件交换机.它会在挂 ...

  10. iOS开发之UIMenuController

    1.简介 用于剪切.复制.粘贴.选择.选择ALL和DELETE命令的菜单界面. UITextField.UIWebView.UITextView自带有这种UIMenuController效果: 2.相 ...