经典线段树 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 ...
随机推荐
- SQL添加列、非空、默认值
use MarcoBarcode go alter table [dbo].[WorkOrderRepairSheet] ADD needRepair int go ALTER TABLE [dbo] ...
- TBLASTN
TBLASTN search translated nucleotide databases using a protein query
- 剑指offer系列(六)
题目描述: 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList,例如按照链表顺序,1->2->3->4->5->6->7->8,那么我们将得到{8 ...
- WEB前段(HTML+JS),后端(MYSQL+PHP)开发基础
一.HTML HTML:超文本标记语言,可以加载JS/CSS/图片/链接等非文字的内容 一切的网页开发技术都需要建立在HTML的基础之上 HTML的结构和语法 HTML元素 注释: <!-- ...
- UVA - 211 The Domino Effect(多米诺效应)(dfs回溯)
题意:根据多米诺骨牌的编号的7*8矩阵,每个点可以和相邻的点组成的骨牌对应一个编号,问能形成多少种由编号组成的图. 分析:dfs,组成的图必须有1~28所有编号. #pragma comment(li ...
- CGridCtrl只点击规定行中的按钮才弹出对话框
在头文件中添加: afx_msg void OnClick(NMHDR* pNMHDR, LRESULT* pResult); 添加映射:ON_NOTIFY(NM_CLICK, IDC_CUSTOM1 ...
- netty权威指南学习笔记三——TCP粘包/拆包之粘包现象
TCP是个流协议,流没有一定界限.TCP底层不了解业务,他会根据TCP缓冲区的实际情况进行包划分,在业务上,一个业务完整的包,可能会被TCP底层拆分为多个包进行发送,也可能多个小包组合成一个大的数据包 ...
- 聚类之K均值聚类和EM算法
这篇博客整理K均值聚类的内容,包括: 1.K均值聚类的原理: 2.初始类中心的选择和类别数K的确定: 3.K均值聚类和EM算法.高斯混合模型的关系. 一.K均值聚类的原理 K均值聚类(K-means) ...
- 【CS224n-2019学习笔记】Lecture 1: Introduction and Word Vectors
附上斯坦福cs224n-2019链接:https://web.stanford.edu/class/archive/cs/cs224n/cs224n.1194/ 文章目录 1.课程简单介绍 1.1 本 ...
- Windows + Python + flup + flask + fastcgi + Nginx配置
Nginx配置 # HTTPS server { listen ssl; server_name kvaccount.xx.io; ssl_certificate "C:/xx/conf/s ...