时间: 1000ms / 空间: 131072KiB / Java类名: Main

描述

    小新经常陪小白去公园玩,也就是所谓的遛狗啦…在小新家附近有一条“公园路”,路的一边从南到北依次排着n个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩了。
    一开始,小白就根据公园的风景给每个公园打了分-.-。小新为了省事,每次遛狗的时候都会事先规定一个范围,小白只可以选择第a个和第b个公园之间(包括a、b两个公园)选择连续的一些公园玩。小白当然希望选出的公园的分数总和尽量高咯。同时,由于一些公园的景观会有所改变,所以,小白的打分也可能会有一些变化。
    那么,就请你来帮小白选择公园吧。

输入格式

    第一行,两个整数N和M,分别表示表示公园的数量和操作(遛狗或者改变打分)总数。
    接下来N行,每行一个整数,依次给出小白 开始时对公园的打分。
    接下来M行,每行三个整数。第一个整数K,1或2。K=1表示,小新要带小白出去玩,接下来的两个整数a和b给出了选择公园的范围(1≤a,b≤N);K=2表示,小白改变了对某个公园的打分,接下来的两个整数p和s,表示小白对第p个公园的打分变成了s(1≤p≤N)。
    其中,1≤N≤500 000,1≤M≤100 000,所有打分都是绝对值不超过1000的整数。

输出格式

    小白每出去玩一次,都对应输出一行,只包含一个整数,表示小白可以选出的公园得分和的最大值。

测试样例1

输入

5 3 
1 2 -3 4 5 
1 2 3 
2 2 -1 
1 2 3

输出


-1

线段树结点维护:区间内最大答案,区间从左端开始的最大答案,从右端开始的最大答案,区间总和。

然后花式维护即可。

  1. /*by SilverN*/
  2. #include<algorithm>
  3. #include<iostream>
  4. #include<cstring>
  5. #include<cstdio>
  6. #include<cmath>
  7. #define lc rt<<1
  8. #define rc rt<<1|1
  9. using namespace std;
  10. const int mxn=;
  11. int read(){
  12. int x=,f=;char ch=getchar();
  13. while(ch<'' || ch>''){if(ch=='-')f=-;ch=getchar();}
  14. while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
  15. return x*f;
  16. }
  17. int n,m;
  18. int data[mxn];
  19. struct node{
  20. int mx;
  21. int ml,mr;
  22. int smm;
  23. }t[mxn<<],tmp0;
  24. void push_up(int l,int r,int rt){
  25. t[rt].smm=t[lc].smm+t[rc].smm;
  26. t[rt].mx=max(t[lc].mx,t[rc].mx);
  27. t[rt].mx=max(t[lc].mr+t[rc].ml,t[rt].mx);
  28. t[rt].ml=max(t[lc].ml,t[lc].smm+t[rc].ml);
  29. t[rt].mr=max(t[rc].mr,t[rc].smm+t[lc].mr);
  30. return;
  31. }
  32. void Build(int l,int r,int rt){
  33. if(l==r){t[rt].mx=t[rt].ml=t[rt].mr=data[l];t[rt].smm=data[l];return;}
  34. int mid=(l+r)>>;
  35. Build(l,mid,lc);
  36. Build(mid+,r,rc);
  37. push_up(l,r,rt);
  38. return;
  39. }
  40. void change(int p,int v,int l,int r,int rt){
  41. if(l==r){
  42. if(p==l){t[rt].ml=t[rt].mr=t[rt].mx=t[rt].smm=v;}
  43. return;
  44. }
  45. int mid=(l+r)>>;
  46. if(p<=mid)change(p,v,l,mid,lc);
  47. else change(p,v,mid+,r,rc);
  48. push_up(l,r,rt);
  49. return;
  50. }
  51. node query(int L,int R,int l,int r,int rt){
  52. // printf("%d %d %d %d %d\n",L,R,l,r,rt);
  53. if(L<=l && r<=R){return t[rt];}
  54. int mid=(l+r)>>;
  55. node res1;
  56. if(L<=mid)res1=query(L,R,l,mid,lc);
  57. else res1=tmp0;
  58. node res2;
  59. if(R>mid)res2=query(L,R,mid+,r,rc);
  60. else res2=tmp0;
  61. node res={};
  62. res.smm=res1.smm+res2.smm;
  63. res.mx=max(res1.mx,res2.mx);
  64. res.mx=max(res.mx,res1.mr+res2.ml);
  65. res.ml=max(res1.ml,res1.smm+res2.ml);
  66. res.mr=max(res2.mr,res2.smm+res1.mr);
  67. return res;
  68. }
  69. int main(){
  70. n=read();m=read();
  71. int i,j,x,y,k;
  72. for(i=;i<=n;i++)data[i]=read();
  73. Build(,n,);
  74. tmp0.ml=tmp0.mr=tmp0.mx=-1e9;tmp0.smm=;
  75. for(i=;i<=m;i++){
  76. k=read();x=read();y=read();
  77. if(k==){
  78. if(x>y)swap(x,y);
  79. printf("%d\n",query(x,y,,n,).mx);
  80. }
  81. else change(x,y,,n,);
  82. }
  83. return ;
  84. }

TYVJ1427 小白逛公园的更多相关文章

  1. [vijos P1083] 小白逛公园

    不知怎地竟有种错觉此题最近做过= =目测是类似的?那道题貌似是纯动归? 本来今晚想做两道题的,一道是本题,一道是P1653疯狂的方格取数或NOI08 Employee,看看现在的时间目测这个目标又达不 ...

  2. Bzoj 1756: Vijos1083 小白逛公园 线段树

    1756: Vijos1083 小白逛公园 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 1021  Solved: 326[Submit][Statu ...

  3. BZOJ 1756: Vijos1083 小白逛公园

    题目 1756: Vijos1083 小白逛公园 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 856  Solved: 264[Submit][Sta ...

  4. JDOJ-P1260 VIJOS-P1083 小白逛公园

    首先,在这里给大家推荐一个网站,https://neooj.com:8082,这是我母校的网站 言归正传,题目描述 VIJOS-P1083 小白逛公园 Time Limit: 1 Sec  Memor ...

  5. 线段树 || BZOJ1756: Vijos1083 小白逛公园 || P4513 小白逛公园

    题面:小白逛公园 题解: 对于线段树的每个节点除了普通线段树该维护的东西以外,额外维护lsum(与左端点相连的最大连续区间和).rsum(同理)和sum……就行了 代码: #include<cs ...

  6. 洛谷 P4513 小白逛公园-区间最大子段和-分治+线段树区间合并(单点更新、区间查询)

    P4513 小白逛公园 题目背景 小新经常陪小白去公园玩,也就是所谓的遛狗啦… 题目描述 在小新家附近有一条“公园路”,路的一边从南到北依次排着nn个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩 ...

  7. vijos1083:小白逛公园

    小白逛公园 描述 小新经常陪小白去公园玩,也就是所谓的遛狗啦…在小新家附近有一条“公园路”,路的一边从南到北依次排着n个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩了. 一开始,小白就根据公园的 ...

  8. 小白逛公园加强版(park)

    小白逛公园加强版(park) 题目描述 小新经常陪小白去公园玩,也就是所谓的遛狗啦--在小新家附近有n个公园,这些公园通过一些路径相连,并保证每两个公园之间有且仅有一条通路相连(也就是说这是一棵树), ...

  9. bzoj1756 Vijos1083 小白逛公园

    Description 小新经常陪小白去公园玩,也就是所谓的遛狗啦-在小新家附近有一条"公园路",路的一边从南到北依次排着n个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩了. ...

随机推荐

  1. Post model至Web Api创建或是保存数据

    前一篇<Post model至Web Api>http://www.cnblogs.com/insus/p/4343538.html中,使用Post来从Web Api获取数据.由于Post ...

  2. typeof关键字简介 -rtti

    typeof关键字是C语言中的一个新扩展.只要可以接受typedef名称,Sun Studio C 编译器就可以接受带有typeof的结构,包括以下语法类别: 声明 函数声明符中的参数类型链表和返回类 ...

  3. python数字图像处理(19):骨架提取与分水岭算法

    骨架提取与分水岭算法也属于形态学处理范畴,都放在morphology子模块内. 1.骨架提取 骨架提取,也叫二值图像细化.这种算法能将一个连通区域细化成一个像素的宽度,用于特征提取和目标拓扑表示. m ...

  4. grunt使用入门(zz)

    下面介绍grunt的基本使用方法,把前端项目中的对个js文件,合并到一起,并压缩. 注意,例子用的是grunt 0.4.5版本,低版本可能在配置上有所不同. 工具/原料 node 方法/步骤 首先用n ...

  5. Last-Modified,Etag,Expire区别

    Last-Modified 是什么 Last-Modified 是 HttpHeader 中的资源的最后修改时间,如果带有 Last-Modified ,下一次发送 Http 请求时,将会发生带 If ...

  6. MVC5 + EF6 + Bootstrap3 (15) 应用ModelState和Data Annotation做服务器端数据验证

    Slark.NET-博客园 http://www.cnblogs.com/slark/p/mvc5-ef6-bs3-get-started-server-side-validation.html 系列 ...

  7. http缓存提高性能

    秋招也算是正式结束了,现在整理一下笔记,当作巩固一下知识,也希望这个对大家有帮助 http 缓存 和 cdn 缓存可以说是面试必问的问题,竟然是必问的问题,那就总结全面一点- http缓存机制 缓存分 ...

  8. QTableView 添加进度条

    记录一下QTableView添加进度条 例子很小,仅供学习 使用QItemDelegate做的实现 有自动更新进度 要在.pro文件里添加 CONFIG += c++ ProgressBarDeleg ...

  9. C#微信开发小白成长教程二(新手接入指南,附视频)

    距离第一讲又已经过去了一个多星期了,本打算一周更新一讲的,奈何实在太忙.最近也在群里发现有一部分人已经可以熟练调用微信的部分接口但却不是很清楚微信公众平台接收消息的一个处理机制.本讲就来介绍下怎么接入 ...

  10. weinre 简记

    在入职不久接触了移动端WEB开发,刚开始遇到的问题就是调试的问题.在PC端的时候,我常常纠结在IE与IE之间,主要的兼容问题还是IE一家子和他们的亲戚(啥多核浏览器,也是各种坑不断)之间.IE虽然问题 ...