如此之裸…

Code:

#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
const int maxn = 200000 + 3;
int x[maxn], y[maxn], n, m, len;
long long nex[maxn], nexx[maxn], maxv[maxn << 2], C[maxn];
inline long long dist(int i,int j){ return abs(x[i] - x[j]) + abs(y[i] - y[j]); }
void build(int l,int r , int o)
{
if(l > r) return ;
if(l == r)
{
maxv[o] = nexx[l];
return;
}
int mid = (l + r) >> 1, ls = (o << 1), rs = (o << 1)|1;
build(l, mid , ls);
build(mid + 1, r, rs);
maxv[o] = max(maxv[ls], maxv[rs]);
}
inline long long query(int l,int r,int L,int R,int o)
{
if(l > r || r < L || l > R) return 0;
if(l >= L && r <= R)
{
return maxv[o];
}
int mid = (l + r) >> 1, ls = (o << 1), rs = (o << 1) | 1;
long long ans = 0;
ans = max(ans, query(l, mid,L,R,ls));
ans = max(ans, query(mid + 1, r, L,R,rs));
return ans;
}
void change(int l,int r,int pos,int o)
{
if(l > r || r < pos || l > pos) return ;
if(l == r)
{
maxv[o] = nexx[pos];
return ;
}
int mid = (l + r) >> 1, ls = (o<<1), rs = (o << 1) |1;
change(l,mid,pos,ls);
change(mid + 1,r,pos,rs);
maxv[o] = max(maxv[ls], maxv[rs]);
}
int lowbit(int t){ return t & (-t); }
inline void update(int x,long long delta)
{
while(x <= n)
{
C[x] += delta;
x += lowbit(x);
}
}
inline long long ask(int x)
{
long long sums = 0;
while(x > 0)
{
sums += C[x];
x -= lowbit(x);
}
return sums;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i = 1;i <= n; ++i) scanf("%d%d",&x[i],&y[i]);
for(int i = 1;i <= n; ++i) { if(i < n)nex[i] = dist(i, i + 1); update(i, dist(i,i - 1));}
for(int i = 1;i <= n - 2; ++i) nexx[i] = nex[i] + nex[i + 1] - dist(i, i + 2);
len = n - 2;
build(1, len, 1);
for(int i = 1;i <= m; ++i)
{
char op[10];
scanf("%s",op);
if(op[0] == 'Q')
{
int st, ed;
scanf("%d%d",&st,&ed);
long long s_ed = ask(ed);
long long s_st = ask(st);
printf("%lld\n",s_ed - s_st - query(1,len,st,ed - 2,1));
}
else
{
int id, a,b;
scanf("%d%d%d",&id,&a,&b);
update(id, -dist(id - 1, id));
update(id + 1, -dist(id, id + 1));
x[id] = a, y[id] = b;
nex[id - 1] = dist(id - 1, id);
nex[id] = dist(id, id + 1);
if(id + 2 <= n)
{
nexx[id] = nex[id] + nex[id + 1] - dist(id, id + 2);
change(1,len, id, 1);
}
if(id - 1 > 0 )
{
nexx[id - 1] = nex[id - 1] + nex[id] - dist(id - 1, id + 1);
change(1,len,id - 1,1);
}
if(id - 2 >= 1)
{
nexx[id -2] = nex[id - 2] + nex[id - 1] - dist(id - 2, id);
change(1,len,id - 2,1);
}
update(id, dist(id - 1, id));
update(id + 1, dist(id, id + 1));
}
}
return 0;
}

洛谷P3113 [USACO14DEC]马拉松赛跑Marathon_Gold 线段树维护区间最大值 模板的更多相关文章

  1. 洛谷P4243/bzoj1558 [JSOI2009]等差数列(线段树维护差分+爆炸恶心的合并)

    题面 首先感谢这篇题解,是思路来源 看到等差数列,就会想到差分,又有区间加,很容易想到线段树维护差分.再注意点细节,\(A\)操作完美解决 然后就是爆炸恶心的\(B\)操作,之前看一堆题解的解释都不怎 ...

  2. 洛谷 P4198 楼房重建 线段树维护单调栈

    P4198 楼房重建 题目链接 https://www.luogu.org/problemnew/show/P4198 题目描述 小A的楼房外有一大片施工工地,工地上有N栋待建的楼房.每天,这片工地上 ...

  3. 51nod 1376【线段树维护区间最大值】

    引自:wonter巨巨的博客 定义 dp[i] := 以数字 i(不是下标 i)为结尾的最长上升长度 然后用线段树维护 dp[i]: 每个节点维护 2 个信息,一个是当前区间的最大上升长度,一个是最大 ...

  4. HDU 2795 Billboard 【线段树维护区间最大值&&查询变形】

    任意门:http://acm.hdu.edu.cn/showproblem.php?pid=2795 Billboard Time Limit: 20000/8000 MS (Java/Others) ...

  5. hdu1754线段树维护区间最大值

    #include <iostream> #include <cstdio> using namespace std; #define MAXN 200005 int N,M; ...

  6. 【HDOJ 1337】I Hate It(线段树维护区间最大值)

    Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少.这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写 ...

  7. 洛谷P3928 Sequence2(dp,线段树)

    题目链接: 洛谷 题目大意在描述底下有.此处不赘述. 明显是个类似于LIS的dp. 令 $dp[i][j]$ 表示: $j=1$ 时表示已经处理了 $i$ 个数,上一个选的数来自序列 $A[0]$ 的 ...

  8. 洛谷P2894[USACO08FEB]酒店Hotel(线段树)

    问题描述 奶牛们最近的旅游计划,是到苏必利尔湖畔,享受那里的湖光山色,以及明媚的阳光.作为整个旅游的策划者和负责人,贝茜选择在湖边的一家著名的旅馆住宿.这个巨大的旅馆一共有N (1 <= N & ...

  9. 洛谷P2574 XOR的艺术(线段树)——Chemist

    当线段树遇上无敌位运算! 还是老套路,线段树维护区间和,一个区间有几个"1"就是这个区间的区间和,同时支持区间修改区间查询,只不过操作从加法变成了异或.主要难点就在更新懒标记那里, ...

随机推荐

  1. tp5 封装百度地图api接口

    //服务器端api extend\Map <?php /** * 百度地图业务封装 */ class Map{ /** * 根据地址来获取经纬度 * @param $address */ pub ...

  2. spring-boot 访问时,加与不加项目名分析

    众所周知,springboot非常便捷,可以简化项目开启步骤,加快开发进度. 很多新手也许都遇到过这样一个问题,在以往的springMvc项目里,大家伙都是把打的war放在tomcat中运行,下意识的 ...

  3. 解决win10系统中将JDK1.8切换到JDK1.7时一直失败的问题

    场景:win10系统安装了1.7版本的JDK后,又安装了1.8版本的JDK,在后面的使用中想进行互相切换,但是1.8切换到1.7时一直失败   第一步:  删除 C:\Windows\System32 ...

  4. BZOJ 3930 Luogu P3172 选数 (莫比乌斯反演)

    手动博客搬家:本文发表于20180310 11:46:11, 原地址https://blog.csdn.net/suncongbo/article/details/79506484 题目链接: (Lu ...

  5. (33)Spring Boot 监控和管理生产环境【从零开始学Spring Boot】

    [本文章是否对你有用以及是否有好的建议,请留言] spring-boot-actuator模块提供了一个监控和管理生产环境的模块,可以使用http.jmx.ssh.telnet等拉管理和监控应用.审计 ...

  6. 2767 Proving Equivalences 至少加几条边让全部图变成强连通模板题

    #include<stdio.h> #include<string.h> #define N 21000 struct node { int u,v,next; }bian[N ...

  7. [MGR——Mysql的组复制之单主模式 ]详细搭建部署过程

    1,关于MySQL Group Replication   基于组的复制(Group-basedReplication)是一种被使用在容错系统中的技术.Replication-group(复制组)是由 ...

  8. [DLX精确覆盖] hdu 3663 Power Stations

    题意: 给你n.m.d,代表有n个城市.m条城市之间的关系,每一个城市要在日后d天内都有电. 对于每一个城市,都有一个发电站,每一个发电站能够在[a,b]的每一个连续子区间内发电. x城市发电了.他相 ...

  9. 【编码格式错误】SyntaxError: Non-UTF-8 code starting with

    问题: SyntaxError: Non-UTF-8 code starting with '\xba' in file E:/placement/placement/Placement Test/c ...

  10. Red Hat Linux虚拟机与主机共享文件

    前置条件:linux上安装了VMware_Tool 参考https://dieyaxianju.cnblogs.com/EditPosts.aspx?postid=6829590 一.首先在本机上新建 ...