POJ 2750 Potted Flower(线段树+dp)
虽然是看的别的人思路,但是做出来还是挺高兴的。
首先求环上最大字段和,而且不能是含有全部元素。本来我的想法是n个元素变为2*n个元素那样做的,这样并不好弄。实际可以求出最小值,总和-最小,就可以求出,断开的情况了。
然后线段树要单点更新,这种标记,以前遇到过,不过一直没有写过,注意总和好更新,整个这一段的结果也很好更新,最难想的就是左边 和右边标记的结果,具体看pushup代码。
#include <cstring>
#include <cstdio>
#include <string>
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
using namespace std;
#define maxn 100100
struct node
{
int sum,lmax,lmin,rmin,rmax;
int smax,smin;
}p[*maxn];
void pushup(int rt)
{
p[rt].sum = p[rt<<].sum + p[rt<<|].sum;
p[rt].smax = max(max(p[rt<<].smax,p[rt<<|].smax),p[rt<<].rmax+p[rt<<|].lmax);
p[rt].lmax = max(p[rt<<].lmax,p[rt<<].sum+p[rt<<|].lmax);
p[rt].rmax = max(p[rt<<|].rmax,p[rt<<|].sum+p[rt<<].rmax);
p[rt].smin = min(min(p[rt<<].smin,p[rt<<|].smin),p[rt<<].rmin + p[rt<<|].lmin);
p[rt].lmin = min(p[rt<<].lmin,p[rt<<].sum+p[rt<<|].lmin);
p[rt].rmin = min(p[rt<<|].rmin,p[rt<<|].sum+p[rt<<].rmin);
}
void build(int l,int r,int rt)
{
int m;
if(l == r)
{
scanf("%d",&p[rt].sum);
p[rt].lmax = p[rt].sum;
p[rt].rmax = p[rt].sum;
p[rt].smax = p[rt].sum;
p[rt].lmin = p[rt].sum;
p[rt].rmin = p[rt].sum;
p[rt].smin = p[rt].sum;
return ;
}
m = (l+r)>>;
build(l,m,rt<<);
build(m+,r,rt<<|);
pushup(rt);
}
void update(int x,int sc,int l,int r,int rt)
{
int m;
if(l == x&&r == x)
{
p[rt].sum = sc;
p[rt].lmax = p[rt].sum;
p[rt].rmax = p[rt].sum;
p[rt].smax = p[rt].sum;
p[rt].lmin = p[rt].sum;
p[rt].rmin = p[rt].sum;
p[rt].smin = p[rt].sum;
return ;
}
m = (l+r)>>;
if(x <= m)
update(x,sc,l,m,rt<<);
if(x > m)
update(x,sc,m+,r,rt<<|);
pushup(rt);
}
int main()
{
int n,m,i,a,b;
while(scanf("%d",&n)!=EOF)
{
build(,n,);
scanf("%d",&m);
for(i = ;i <= m;i ++)
{
scanf("%d%d",&a,&b);
update(a,b,,n,);
if(p[].sum == p[].smax)//如果总和和最大值相同,断开一个最小值。
{
printf("%d\n",p[].sum - p[].smin);
}
else
{
printf("%d\n",max(p[].smax,p[].sum-p[].smin));
}
}
}
return ;
}
POJ 2750 Potted Flower(线段树+dp)的更多相关文章
- POJ.2750.Potted Flower(线段树 最大环状子段和)
题目链接 /* 13904K 532ms 最大 环状 子段和有两种情况,比如对于a1,a2,a3,a4,a5 一是两个端点都取,如a4,a5,a1,a2,那就是所有数的和减去不选的,即可以计算总和减最 ...
- POJ 2750 Potted Flower (线段树区间合并)
开始懵逼找不到解法,看了网上大牛们的题解才发现是区间合并... 给你n个数形成一个数列环,然后每次进行一个点的修改,并输出这个数列的最大区间和(注意是环,并且区间最大只有n-1个数) 其实只需要维护 ...
- Potted Flower(线段树+dp)
http://poj.org/problem?id=2750 题意:在一个圈中取若干个相邻的数,求他们的最大序列和.不能够同时取所有的数. 看了一篇解题报告写的很详细..http://blog.csd ...
- POJ 2750 Potted Flower
Potted Flower Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 3872 Accepted: 1446 Des ...
- POJ 2750 Potted Flower(线段树的区间合并)
点我看题目链接 题意 : 很多花盆组成的圆圈,每个花盆都有一个值,给你两个数a,b代表a位置原来的数换成b,然后让你从圈里找出连续的各花盆之和,要求最大的. 思路 :这个题比较那啥,差不多可以用DP的 ...
- (简单) POJ 2750 Potted Flower,环+线段树。
Description The little cat takes over the management of a new park. There is a large circular statue ...
- POJ.1769.Minimizing maximizer(线段树 DP)
题目链接 /* 题意:有m个区间,问最少要多少个区间能覆盖[1,n] 注:区间要按原区间的顺序,不能用排序贪心做 设dp[i]表示最右端端点为i时的最小值 dp[e[i]]=min{dp[s[i]]~ ...
- POJ 2750 Potted Flower (单点改动求线段树上最大子序列和)
题目大意: 在一个序列上每次改动一个值,然后求出它的最大的子序列和. 思路分析: 首先我们不考虑不成环的问题.那就是直接求每一个区间的最大值就好了. 可是此处成环,那么看一下以下例子. 5 1 -2 ...
- Tsinsen A1219. 采矿(陈许旻) (树链剖分,线段树 + DP)
[题目链接] http://www.tsinsen.com/A1219 [题意] 给定一棵树,a[u][i]代表u结点分配i人的收益,可以随时改变a[u],查询(u,v)代表在u子树的所有节点,在u- ...
随机推荐
- 【EF 1】EF实体框架 原理+实例
一.知识回顾 到目前为止,自己学到的链接数据库操作已经经历了几个阶段,分别是:学生信息管理和(第一次)机房收费时的直接连接数据库操作表格,然后是机房个人重构中应用的操作实体,在其中还利用了一个很重要的 ...
- 有关git的配置
git版本控制器总结 关于部分内容请参考:https://www.cnblogs.com/smuxiaolei/p/7484678.htmlgit是一个版本控制器,分布式管理:可以记录每次文件的改动, ...
- Title共通写法
用: <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_c ...
- BZOJ 4822 [Cqoi2017]老C的任务 ——树状数组
直接离散化之后用树状数组扫一遍. 把每一个询问拆成四个就可以做了. %Silvernebula 怒写KD-Tree #include <map> #include <cmath> ...
- 算法复习——欧拉回路混合图(bzoj2095二分+网络流)
题目: Description YYD为了减肥,他来到了瘦海,这是一个巨大的海,海中有n个小岛,小岛之间有m座桥连接,两个小岛之间不会有两座桥,并且从一个小岛可以到另外任意一个小岛.现在YYD想骑单车 ...
- 算法复习——差分约束(ssoi种树)
题目: 题目描述 为了绿化乡村,H 村积极响应号召,开始种树了. H 村里有 n 幢房屋,这些屋子的排列顺序很有特点,在一条直线上.于是方便起见,我们给它们标上 1-n .树就种在房子前面的空地上. ...
- NCCloud 指令示例
http://ansrlab.cse.cuhk.edu.hk/software/nccloud/ Implementation of NCCloud in C++ (updated: August 2 ...
- Codevs 2602 最短路径问题
时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题目描述 Description 平面上有n个点(n<=100),每个点的坐标均在-10000~10000之间. ...
- Bootstrap开启模态框后对数据处理(标记模态框的开启与关闭状态)
JS用全局变量标记状态,方法中动态修改全局变量以标记状态是一个重要思想. 需求:组合条件查询数据,查询完之后填充到模态框中,开启模态框,模态框中有组合条件查询,此时查询只需要更新模态框表格数据不需要开 ...
- ftrace 提供的工具函数
内核头文件 include/linux/kernel.h 中描述了 ftrace 提供的工具函数的原型,这些函数包括 trace_printk.tracing_on/tracing_off 等.本文通 ...