线段树然后yy一下,搞一搞。

GSS1:

题意:求最大区间和。

#include <cstdio>
#include <algorithm>
using namespace std;
int lm[200005],rm[200005],ma[200005],s[200005],left,right,n,m,ans,rans;
void build(int l,int r,int num){
if(l==r){scanf("%d",&ma[num]);rm[num]=lm[num]=s[num]=ma[num];return;}
int mid=(l+r)/2;
build(l,mid,num*2);
build(mid+1,r,num*2+1);
s[num]=s[num*2]+s[num*2+1];
lm[num]=max(lm[num*2],s[num*2]+lm[num*2+1]);
rm[num]=max(rm[num*2+1],s[num*2+1]+rm[num*2]);
ma[num]=max(lm[num*2+1]+rm[num*2],max(ma[num*2+1],ma[num*2]));
}
void find(int l,int r,int num){
if(l>=left&&r<=right){
ans=max(ans,max(ma[num],rans+lm[num]));
rans=max(rm[num],rans+s[num]);
return;
}
int mid=(l+r)/2;
if(mid>=left)find(l,mid,num*2);
if(mid<right)find(mid+1,r,num*2+1);
}
int main()
{
scanf("%d",&n);
build(1,n,1);
scanf("%d",&m);
for(int i=1;i<=m;i++)
{
scanf("%d%d",&left,&right);
rans=ans=-1*0x3fffffff,find(1,n,1),printf("%d\n",ans);
}
}

GSS3:

GSS3就是GSS1加一个修改操作。

#include <cstdio>
#include <cstring>
#include <algorithm>
#define inf 0x3fffffff
#define N 2000000
using namespace std;
int n,m,s[N],ma[N],lm[N],rm[N],jy,le,ri,ans,rans;
void bu(int l,int r,int num){
if(l==r){scanf("%d",&s[num]),ma[num]=lm[num]=s[num]=rm[num]=s[num];return;}
int m=(l+r)/2;
bu(l,m,num*2);bu(m+1,r,num*2+1);
lm[num]=max(lm[num*2],lm[num*2+1]+s[num*2]);
rm[num]=max(rm[num*2+1],s[num*2+1]+rm[num*2]);
s[num]=s[num*2]+s[num*2+1];
ma[num]=max(ma[num*2],max(ma[num*2+1],lm[num*2+1]+rm[num*2]));
}
void fi(int l,int r,int num){
if(l>=le&&r<=ri){
ans=max(ans,max(ma[num],rans+lm[num]));
rans=max(rm[num],rans+s[num]);
return;
}
int m=(l+r)/2;
if(m>=le)fi(l,m,num*2);
if(m<ri)fi(m+1,r,num*2+1);
}
void ch(int l,int r,int num){
if(l==r){ma[num]=lm[num]=s[num]=rm[num]=s[num]=ri;return;}
int m=(l+r)/2;
if(m>=le)ch(l,m,num*2);
else ch(m+1,r,num*2+1);
lm[num]=max(lm[num*2],lm[num*2+1]+s[num*2]);
rm[num]=max(rm[num*2+1],s[num*2+1]+rm[num*2]);
s[num]=s[num*2]+s[num*2+1];
ma[num]=max(ma[num*2],max(ma[num*2+1],lm[num*2+1]+rm[num*2]));
}
int main()
{
scanf("%d",&n);
bu(1,n,1);
scanf("%d",&m);
for(int i=1;i<=m;i++){
scanf("%d%d%d",&jy,&le,&ri);
if(jy){rans=ans=-inf;fi(1,n,1);printf("%d\n",ans);}
else ch(1,n,1);
}
}

GSS5写挂ing……自己写了个对拍,和网上AC的code拍,一开始还找出来点儿错,交上去,WA,,,完之后就不知道错哪了,ZRT只是说我的maker写得没有问题,还说什么线段树的错特别难找。。就挂了。。。。。。

放个WA code吧。。。(但是至少能水掉90%的官方数据,100%我的自测数据。。目前已拍30000多组)

#include <cstdio>
#include <cstring>
#include <algorithm>
#define inf 0x3fffffff
#define N 2000000
using namespace std;
int n,m,s[N],ma[N],lm[N],rm[N],jy,ans,rans,lans,cases;
void bu(int l,int r,int num){
if(l==r){scanf("%d",&s[num]),ma[num]=lm[num]=s[num]=rm[num]=s[num];return;}
int m=(l+r)/2;
bu(l,m,num*2);bu(m+1,r,num*2+1);
lm[num]=max(lm[num*2],lm[num*2+1]+s[num*2]);
rm[num]=max(rm[num*2+1],s[num*2+1]+rm[num*2]);
s[num]=s[num*2]+s[num*2+1];
ma[num]=max(ma[num*2],max(ma[num*2+1],lm[num*2+1]+rm[num*2]));
}
void fm(int left,int right,int l,int r,int num){
if(l>=left&&r<=right){
ans=max(ans,max(ma[num],rans+lm[num]));
rans=max(rm[num],rans+s[num]);
return;
}
int m=(l+r)/2;
if(m>=left)fm(left,right,l,m,num*2);
if(m<right)fm(left,right,m+1,r,num*2+1);
}
int fs(int left,int right,int l,int r,int num){
if(left<=l&&right>=r)return s[num];
int m=(l+r)/2,sum=0;
if(m>=left)sum+=fs(left,right,l,m,num*2);
if(m<right)sum+=fs(left,right,m+1,r,num*2+1);
return sum;
}
void fl(int left,int right,int l,int r,int num){
if(left<=l&&right>=r){
rans=max(rans+s[num],rm[num]);
return;
}
int m=(l+r)/2;
if(m>=left)fl(left,right,l,m,num*2);
if(m<right)fl(left,right,m+1,r,num*2+1);
}
void fr(int left,int right,int l,int r,int num){
if(left<=l&&right>=r){
lans=max(lans+s[num],lm[num]);
return;
}
int m=(l+r)/2;
if(m<right)fr(left,right,m+1,r,num*2+1);
if(m>=left)fr(left,right,l,m,num*2); }
int main()
{
int x1,x2,y1,y2;
scanf("%d",&cases);
while(cases--){
scanf("%d",&n);
bu(1,n,1);
scanf("%d",&m);
for(int i=1;i<=m;i++){
lans=rans=ans=-inf;
scanf("%d%d%d%d",&x1,&x2,&y1,&y2);
if(y1>x2){
if(x2>x1&&y2>y1){
int Q=fs(x2,y1,1,n,1);
fl(x1,x2-1,1,n,1);
fr(y1+1,y2,1,n,1);
ans=max(Q,max(max(rans+Q,lans+Q),rans+lans+Q));
printf("%d\n",ans);
}
else if(x1==x2){
int Q=fs(x2,y1,1,n,1);
fr(y1+1,y2,1,n,1);
ans=max(lans,lans+Q);
printf("%d\n",ans);
}
else if(y1==y2)
{
int Q=fs(x2,y1,1,n,1);
fl(x1,x2-1,1,n,1);
ans=max(rans,Q+rans);
printf("%d\n",ans);
}
}
else if(y1==x2){
if(x2-1>=x1)fl(x1,x2-1,1,n,1);
if(y1+1<=y2)fr(y1+1,y2,1,n,1);
int Q=fs(y1,y1,1,n,1);
ans=max(Q,max(max(Q+lans,Q+rans),Q+lans+rans));
printf("%d\n",ans);
}
else if(y1<x2){
fl(x1,y1,1,n,1);fr(y1,y2,1,n,1);int Q=fs(y1,y1,1,n,1);
ans=max(rans,max(lans,rans+lans-Q));
rans=lans=-inf;
fl(x1,x2,1,n,1);fr(x2,y2,1,n,1);Q=fs(x2,x2,1,n,1);
ans=max(ans,max(lans,max(rans,rans+lans-Q)));
rans=lans=-inf;
fm(y1,x2,1,n,1);
printf("%d\n",ans);
}
}
}
}

这么杂乱无章&冗长的代码不是我的风格,但是越改代码越丑。。。。。

SPOJ GSS1 & GSS3&挂了的GSS5的更多相关文章

  1. spoj gss1 gss3

    传送门 gss1 gss3 spoj gss系列=最大字段和套餐 gss1就是gss3的无单点修改版 有区间查询和单点修改,考虑用线段树维护 我们要维护区间权值和\(s\),区间最大前缀和\(xl\) ...

  2. SPOJ GSS1 && GSS3 (无更新/更新单点,并询问区间最大连续和)

    http://www.spoj.com/problems/GSS1/ 题意:无更新询问区间最大连续和. 做法:线段树每个节点维护sum[rt],maxsum[rt],lsum[rt],rsum[rt] ...

  3. SPOJ - GSS1&&GSS3

    GSS1 #include<cstdio> #include<iostream> #define lc k<<1 #define rc k<<1|1 u ...

  4. SPOJ GSS1 - Can you answer these queries I(线段树维护GSS)

    Can you answer these queries I SPOJ - GSS1 You are given a sequence A[1], A[2], -, A[N] . ( |A[i]| ≤ ...

  5. [题解] SPOJ GSS1 - Can you answer these queries I

    [题解] SPOJ GSS1 - Can you answer these queries I · 题目大意 要求维护一段长度为 \(n\) 的静态序列的区间最大子段和. 有 \(m\) 次询问,每次 ...

  6. GSS系列(1)——GSS1&&GSS3

    题意:询问一个区间内的最大连续子段和(GSS1),并且有单点修改的操作(GSS2). 思路:这个题目在老人家的大白鼠里出现过,不过那个是求两个下标,并且相同取更小值.——传的东西更多,判断也稍微繁琐一 ...

  7. SPOJ - GSS1 —— 线段树 (结点信息合并)

    题目链接:https://vjudge.net/problem/SPOJ-GSS1 GSS1 - Can you answer these queries I #tree You are given ...

  8. SPOJ GSS1 Can you answer these queries I[线段树]

    Description You are given a sequence A[1], A[2], ..., A[N] . ( |A[i]| ≤ 15007 , 1 ≤ N ≤ 50000 ). A q ...

  9. SPOJ GSS1 Can you answer these queries I

    Time Limit: 115MS   Memory Limit: 1572864KB   64bit IO Format: %lld & %llu Description You are g ...

随机推荐

  1. vue中使用Swiper

    第一步:安装swiper在项目目录下打开命令窗口输入命令:npm install swiper 第二步:引入js文件 第三步:引入css文件在main.js文件中引入css文件

  2. 移动端rem布局 js

    // rem布局适配 (function(doc, win) { var docEl = doc.documentElement, resizeEvt = 'orientationchange' in ...

  3. DOCKER - POD操作

    强制删除 Terminating 的pod kubectl delete  -n <namespace> <pod podname> --grace-period=0 --fo ...

  4. java ArrayList去重复值

    public static List removeDuplicateWithOrder(List list) { Set set = new HashSet(); List newList = new ...

  5. php第十二节课

    练习 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.o ...

  6. 【Android】一个好用的sharedpreferences存储类方法

    其实我也不知道sharedpreferences究竟安全不安全,毕竟是android中最简单的存储机制. 如果你手机root了的话,使用MT管理器到data/data/包名/shared_prefs下 ...

  7. BOM对象和DOM对象

    一.BOM对象 BOM(Browser Object Model)是指浏览器对象模型,可以对浏览器窗口进行访问和操作.使用 BOM,开发者可以移动窗口.改变状态栏中的文本以及执行其他与页面内容不直接相 ...

  8. nlogn求LIS(树状数组)

    之前一直是用二分 但是因为比较难理解,写的时候也容易忘记怎么写. 今天比赛讲评的时候讲了一种用树状数组求LIS的方法 (1)好理解,自然也好写(但代码量比二分的大) (2)扩展性强.这个解法顺带求出以 ...

  9. 使用MySQLMigrationToolkit快速将Oracle数据导入MySQL

    使用MySQL Migration Toolkit快速将Oracle数据导入MySQL 上来先说点废话 本人最近在学习一些数据库方面的知识,之前接触过Oracle和MySQL,最近又很流行MongoD ...

  10. [Cogs728] [网络流24题#3] 最小路径覆盖 [网络流,最大流,二分图匹配]

    建图:源点—>边的起点(集合1中的)—>边的终点(集合2中的)—>汇点,所有边权均为1, 计算最大流,最后枚举起点的出边,边权为0的即为匹配上的, 可以这样理解:每条边表示起点和终点 ...