经典线段树 UVALive 3938/UVA 1400
题意:就是相当于动规里面的求最大连续子串,不同的是,这里需要读入一个区间x,y,输出的区间 a,b 且x<=a<=b<=y,使得a b的连续子串最长,而且询问次数达到了10的五次方。
我是在大白书上看到这个题,一开始想简单了,就照着刘汝佳的思路写,线段树里只存了前缀最大和,后缀最大和,总最大和,但题目要求输出区间,明显的需要添加记录维护区间位置的,而且不止要存储 a,b,还要存pre suf,前缀 后缀的边界位置。我第一次写的时候意识到了,但是那个时候已经有点混乱了,我以为在查询的时候,根据最大和就能确定区间。。。结果真是。。。智商被碾压。
还有个令人心酸的地方,直接导致我WA了整整一版,。。。尼玛,我记得校队选拔赛的时候也是同样的问题卡了我最后一个简单的题目,就是我用的中间变量暂存最大和,我知道最大和肯定会超过int,所以之前就设置了ll,但尼玛我定义中间变量的时候,居然下意识还是用的int。。。。。检查了我N多遍才查出来。。尼玛太心酸了。。一定要注意细节
#include <iostream>
#include <cstdio>
#include <cstring>
#define Lson x<<1,l,mid
#define Rson (x<<1|1),mid+1,r
#define N 500030
using namespace std; struct node//线段树节点只需要记录前缀最右边间位置pre,类似的后缀suf,以及真正的解区间,vx,vy
{
int vx,vy;
int suf,pre;
} tree[N*];
long long s[N];
void getup(int x,int l,int r)
{
if (s[tree[x<<].pre]-s [l-]>=s[tree[x<<|].pre]-s[l-]){
tree[x].pre=tree[x<<].pre;
}
else{
tree[x].pre=tree[x<<|].pre;
}
if (s[r]-s[tree[x<<].suf-]>=s[r]-s[tree[x<<|].suf-]){
tree[x].suf=tree[x<<].suf;
}
else{
tree[x].suf=tree[x<<|].suf;
}
long long v1=s[tree[x<<].vy]-s[tree[x<<].vx-];
long long v2=s[tree[x<<|].vy]-s[tree[x<<|].vx-];
long long v0=s[tree[x<<|].pre]-s[tree[x<<].suf-];
if (v1>=v2){
tree[x].vx=tree[x<<].vx;
tree[x].vy=tree[x<<].vy;
}
else{
tree[x].vx=tree[x<<|].vx;
tree[x].vy=tree[x<<|].vy;
}
if (v0==s[tree[x].vy]-s[tree[x].vx-]){
if (tree[x<<].suf<tree[x].vx){
tree[x].vx=tree[x<<].suf;
tree[x].vy=tree[x<<|].pre;
}
else if (tree[x<<].suf==tree[x].vx && tree[x<<|].pre<tree[x].vy){
tree[x].vy=tree[x<<|].pre;
}
}
if (v0>s[tree[x].vy]-s[tree[x].vx-]){
tree[x].vx=tree[x<<].suf;
tree[x].vy=tree[x<<|].pre;
} }
void build(int x,int l,int r)
{
if (l==r)
{
tree[x].pre=tree[x].suf=tree[x].vy=tree[x].vx=l;
return;
}
int mid=(l+r)/;
build(Lson);
build(Rson);
getup(x,l,r);
}
node query(int st,int e,int x,int l,int r)
{
if (st<=tree[x].vx && tree[x].vy<=e){
return tree[x];
}
int mid=(l+r)/;
if (st>mid){
return query(st,e,Rson);
}
if (e<=mid){
return query(st,e,Lson);
}
node a=query(st,e,Lson);
node b=query(st,e,Rson);
node c;
if (s[a.vy]-s[a.vx-]>=s[b.vy]-s[b.vx-]){
c.vx=a.vx;
c.vy=a.vy;
}
else {
c.vx=b.vx;
c.vy=b.vy;
}
if (s[a.pre]-s[st-]>=s[b.pre]-s[st-]){
c.pre=a.pre;
}
else{
c.pre=b.pre;
}
if (s[e]-s[a.suf-]>=s[e]-s[b.suf-]){
c.suf=a.suf;
}
else{
c.suf=b.suf;
}
if (s[b.pre]-s[a.suf-]==s[c.vy]-s[c.vx-]){
if (a.suf<c.vx){
c.vx=a.suf;
c.vy=b.pre;
}
if (a.suf==c.vx && b.pre<c.vy){
c.vy=b.pre;
}
}
else
if (s[b.pre]-s[a.suf-]>s[c.vy]-s[c.vx-]){
c.vx=a.suf;
c.vy=b.pre;
}
return c;
}
int main()
{
int n,m;
int counts=;
while (scanf("%d%d",&n,&m)!=EOF)
{
int i,j,k;
memset(s,,sizeof s);
long long tt;
for (i=;i<=n;i++){
scanf("%lld",&tt);
s[i]=s[i-]+tt;
}
build(,,n);
printf("Case %d:\n",++counts);
for (i=;i<=m;i++){
int ss,e;
scanf("%d%d",&ss,&e);
node ans=query(ss,e,,,n); printf("%d %d\n",ans.vx,ans.vy);
}
}
return ;
}
经典线段树 UVALive 3938/UVA 1400的更多相关文章
- ZOJ - 1610 经典线段树染色问题
这个是一个经典线段树染色问题,不过题目给的是左右左右坐标,即[0,3]包含0-1这一段 1-2这一段 2-3这一段,和传统的染色不太一样,不过其实也不用太着急. 我们把左边的坐标+1,即可,那么[0, ...
- pku 2777(经典线段树染色问题)
Count Color Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 41202 Accepted: 12458 Des ...
- poj-2828 Buy Tickets(经典线段树)
/* Buy Tickets Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 10207 Accepted: 4919 Descr ...
- poj 2528 poster经典线段树+lazy+离散化
#include<cstdio> #include<cstring> #include<algorithm> using namespace std; ; #def ...
- ZOJ1610(经典线段树涂色问题)
Description Painting some colored segments on a line, some previously painted segments may be covere ...
- poj Hotel 线段树
经典线段树的题. 每个节点存储的信息:左端点连续空房间的长度,右端点连续空房间长度,连续空房间的最大长度. 由于要求每次必须从尽量靠左边的位置进行居住,那么搜索时应尽量让区间起始位置更小: 1.如果当 ...
- 『zkw线段树及其简单运用』
阅读本文前,请确保已经阅读并理解了如下两篇文章: 『线段树 Segment Tree』 『线段树简单运用』 引入 这是一种由\(THU-zkw\)大佬发明的数据结构,本质上是经典的线段树区间划分思想, ...
- 线段树模板hdu 1166:敌兵布阵
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- 线段树模板hdu 1754:I Hate It
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
随机推荐
- 035、Java中自增之++在后面的写法
01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...
- Web application architecture overview
- [强网杯 2019]Upload
0x00 知识点 代码审计,PHP 反序列化. 0x01 解题 先注册一个账号,再登陆 上传 简单测试一下: 只能上传能被正常查看的 png. F12看到文件上传路径 扫扫敏感文件 存在:/www.t ...
- 觉醒 闭包/this
两条非常重要的知识点 首先上题 var a = '322' var preview = function() { var a = '123' console.log(a, this, this.a) ...
- hihocoder 1241:Best Route in a Grid
#1241 : Best Route in a Grid 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定一个N行N列的非负整数方阵,从左上角(1,1)出发,只能向下 ...
- CSS屏幕适配尺寸样式
/* 大屏幕 :大于等于1200px*/@media (min-width: 1200px) { ... } /*默认*/@media (min-width: 980px){...} /* 平板电脑和 ...
- js实现二叉查找树
二叉树的特点: 像一颗树一样,从顶端往下延伸,最顶端的为根节点,每个节点下面子节点的数不超过两个,没有任何子节点的节点被称为叶子节点, 除了根节点和叶子节点的被称为中间节点. 二叉查找树: 每个节 ...
- [LeetCode] 934. Shortest Bridge 最短的桥梁
In a given 2D binary array A, there are two islands. (An island is a 4-directionally connected grou ...
- Oracle之SQL优化专题03-如何看懂SQL的执行计划
专题第一篇<Oracle之SQL优化专题01-查看SQL执行计划的方法>讲到了查看SQL执行计划的方法,并介绍了各种方法的应用场景,那么这一篇就主要介绍下如何看懂SQL的执行计划.毕竟如果 ...
- 16.swoole学习笔记--异步事件
<?php //异步事件 $fp=stream_socket_client(); fwrite($fp,"GET / HTTP/1.1\r\nHost:www.qq.com\r\n\r ...