6356.Glad You Came

题意就是给你一个随机生成函数,然后从随机函数里确定查询的左右区间以及要更新的val值。然后最后求一下异或和就可以了。

线段树,区间最大值和最小值维护一下,因为数据有点大,不剪枝就会超时。(默默吐槽,剪了枝照样超时)

因为太菜,交了24遍也是没过,TLE,WA,RE轮流来,而且感觉这题有毒,删一个没用的变量就会WA。。。

百度了一下题解,发现有人和我写的几乎一模一样,但是人家的就可以过,我的死也过不去。

人家的博客:HDU6356 Glad You Came(线段树区间更新+剪枝)

贴一下人家的代码:

 #include<bits/stdc++.h>
using namespace std;
typedef unsigned int ui;
typedef long long ll;
const int maxn = 1e5 + ;
const int maxm = 5e6 + ;
const ui mod = << ;
ui x, y, z, w, f[*maxm], Left[maxm], Right[maxm], v[maxm];
ui fun()
{
x ^= (x << );
x ^= (x >> );
x ^= (x << );
x ^= (x >> );
w = x ^ (y ^ z);
x = y;
y = z;
z = w;
return z;
} ll ans, a[maxn], maxa[maxn<<], mina[maxn<<], lazy[maxn<<];
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define getm int m = l + r >> 1
void pushup(int rt)
{
mina[rt] = min(mina[rt<<],mina[rt<<|]);
maxa[rt] = max(maxa[rt<<],maxa[rt<<|]);
} void pushdown(int rt)
{
if(lazy[rt])
{
lazy[rt<<] = lazy[rt<<|] = lazy[rt];
maxa[rt<<] = maxa[rt<<|] = lazy[rt];
mina[rt<<] = mina[rt<<|] = lazy[rt];
lazy[rt] = ;
}
} void update(ui L,ui R,ui val,int l,int r,int rt)
{
if(mina[rt] >= val) return ;//最小值都比v大,不用更新
if(L <= l && r <= R)
{
if(maxa[rt] <= val)//最大值比v小,全部更新,打标记
{
maxa[rt] = val;
lazy[rt] = val;
return ;
}
//否则继续切分区间,向下更新
} getm;
pushdown(rt);
if(L<=m)
update(L,R,val,lson);
if(R>m)
update(L,R,val,rson);
pushup(rt);
} ll query(int pos,int l,int r,int rt)
{
if(l==r)
return maxa[rt];
getm;
pushdown(rt);
if(pos<=m)
return query(pos,lson);
else
return query(pos,rson);
} int T, N, M;
int main()
{
scanf("%d",&T);
while(T--)
{
memset(a,,*(N+));
memset(lazy,,*(N+));
memset(mina,,*(N+));
memset(maxa,,*(N+));
scanf("%d%d%u%u%u",&N,&M,&x,&y,&z);
for(int i=;i<=*M;++i)
f[i] = fun();
for(int i=;i<=M;++i)
{
Left[i] = min(f[*i-] % N, f[*i-] % N) + ;
Right[i] = max(f[*i-] % N, f[*i-] % N) + ;
v[i] = f[*i] % mod;
update(Left[i],Right[i],v[i],,N,);
}
ans = ;
for(int i=;i<=N;++i)
ans ^= ((ll)i * query(i,,N,));
printf("%lld\n",ans);
}
return ;
}

最后贴一下我的死也没过去的代码,哪个大佬好心看一下,然后拯救一下我。。。

我队友帮我调了也快20发了,依旧没过,哭死༼༎ຶᴗ༎ຶ༽

 //1007-6356-线段树
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<bitset>
#include<cassert>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<ctime>
#include<deque>
#include<iomanip>
#include<list>
#include<map>
#include<queue>
#include<set>
#include<stack>
#include<vector>
using namespace std;
typedef unsigned int ui;
typedef long long ll;
const double PI=acos(-1.0);
const double eps=1e-;
const int inf=0x3f3f3f3f;
const int maxn=1e5+;
const int maxm=5e6+;
const ui mod=<<;
#define ios ios::sync_with_stdio(false);cin.tie(0);cout.tie(0); #define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1 ll lazy[maxn<<],MAX[maxn<<],MIN[maxn<<];
ui x,y,z,w,f[maxm]; void pushup(int rt)
{
MIN[rt]=min(MIN[rt<<],MIN[rt<<|]);
MAX[rt]=max(MAX[rt<<],MAX[rt<<|]);
} void pushdown(int rt)
{
if(lazy[rt]){
lazy[rt<<]=lazy[rt<<|]=lazy[rt];
MAX[rt<<]=MAX[rt<<|]=lazy[rt];
MIN[rt<<]=MIN[rt<<|]=lazy[rt];
lazy[rt]=;
}
} void build(int l,int r,int rt)
{
lazy[rt]=;MAX[rt]=MIN[rt]=;
if(l==r){
return ;
} int m=(l+r)>>;
build(lson);
build(rson);
} void update(ui L,ui R,ui val,int l,int r,int rt)
{
if(MIN[rt]>=val) return ;
if(L<=l&&r<=R){
if(MAX[rt]<=val){
MAX[rt]=val;
lazy[rt]=val;
return ;
}
} pushdown(rt);
int m=(l+r)>>;
if(L<=m) update(L,R,val,lson);
if(R> m) update(L,R,val,rson);
pushup(rt);
} ll query(int pos,int l,int r,int rt)
{
if(l==r){
return MAX[rt];
} pushdown(rt);
int m=(l+r)>>;
if(pos<=m) return query(pos,lson);
if(pos> m) return query(pos,rson);
} ui RNG61()
{
x ^= (x << );
x ^= (x >> );
x ^= (x << );
x ^= (x >> );
w = x ^ (y^z);
x = y;
y = z;
z = w;
return z;
} int t,n,m; int main()
{
scanf("%d",&t);
while(t--){
scanf("%d%d%u%u%u",&n,&m,&x,&y,&z);
build(,n,);
for(int i=;i<=*m;i++)
f[i]=RNG61();
for(int i=;i<=m;i++){
ui l=min(f[*i-]%n,f[*i-]%n)+;
ui r=max(f[*i-]%n,f[*i-]%n)+;
ui v=f[*i]%mod;
update(l,r,v,,n,);
}
ll ans=;
for(int i=;i<=n;i++)
ans^=(ll)i*query(i,,n,);
printf("%lld\n",ans);
}
}

滚了滚了,滚回垃圾桶了。

HDU 6356.Glad You Came-线段树(区间更新+剪枝) (2018 Multi-University Training Contest 5 1007)的更多相关文章

  1. HDU.1556 Color the ball (线段树 区间更新 单点查询)

    HDU.1556 Color the ball (线段树 区间更新 单点查询) 题意分析 注意一下pushdown 和 pushup 模板类的题还真不能自己套啊,手写一遍才行 代码总览 #includ ...

  2. HDU 1556 Color the ball(线段树区间更新)

    Color the ball 我真的该认真的复习一下以前没懂的知识了,今天看了一下线段树,以前只会用模板,现在看懂了之后,发现还有这么多巧妙的地方,好厉害啊 所以就应该尽量搞懂 弄明白每个知识点 [题 ...

  3. (简单) HDU 1698 Just a Hook , 线段树+区间更新。

    Description: In the game of DotA, Pudge’s meat hook is actually the most horrible thing for most of ...

  4. HDU 1698 Just a Hook(线段树区间更新查询)

    描述 In the game of DotA, Pudge’s meat hook is actually the most horrible thing for most of the heroes ...

  5. hdu - 1689 Just a Hook (线段树区间更新)

    http://acm.hdu.edu.cn/showproblem.php?pid=1698 n个数初始每个数的价值为1,接下来有m个更新,每次x,y,z 把x,y区间的数的价值更新为z(1<= ...

  6. 2014多校第四场1006 || HDU 4902 Nice boat (线段树 区间更新)

    题目链接 题意 : 给你n个初值,然后进行两种操作,第一种操作是将(L,R)这一区间上所有的数变成x,第二种操作是将(L,R)这一区间上所有大于x的数a[i]变成gcd(x,a[i]).输出最后n个数 ...

  7. HDU 4614-Vases and Flowers(线段树区间更新)

    题意: n个花瓶(0-n-1) 现有两个操作, 操作1 给a,f 从a位置开始向后连续插f个花(一个花瓶插一个)若当前花瓶有花则向后找,直到n-1位置如果还有多余的花则丢掉求查完花的第一和最后一个位置 ...

  8. HDU 1698 Just a Hook 线段树区间更新、

    来谈谈自己对延迟标记(lazy标记)的理解吧. lazy标记的主要作用是尽可能的降低时间复杂度. 这样说吧. 如果你不用lazy标记,那么你对于一个区间更新的话是要对其所有的子区间都更新一次,但如果用 ...

  9. hdu 1556 Color the ball 线段树 区间更新

    水一下 #include <bits/stdc++.h> #define lson l, m, rt<<1 #define rson m+1, r, rt<<1|1 ...

随机推荐

  1. 【bzoj2438】[中山市选2011]杀人游戏 Tarjan

    题目描述 一位冷血的杀手潜入 Na-wiat,并假装成平民.警察希望能在 N 个人里面,查出谁是杀手.警察能够对每一个人进行查证,假如查证的对象是平民,他会告诉警察,他认识的人, 谁是杀手, 谁是平民 ...

  2. 附录A培训实习生-面向对象基础方法重载(3)

    就上一篇代码而言,你如果写Cat cat = new Cat();会直接报错错误 : 1       “Cat”方法没有采用“0”个参数的重载 E:\大话设计模式学习\BigDesignPattern ...

  3. dp类模板

    1.n串最长公共子序列 #include<cstdio> #include<cstring> #include<algorithm> using namespace ...

  4. 【算法】Prüfer编码 —— HNOI2004树的计数

    的确,如果不知道这个编码的话的确是一脸懵逼.在这里放一篇认为讲的很详细的 BLOG,有关于编码的方式 & 扩展在里面都有所提及. 欢迎点此进入 --> 大佬的博客 在这里主要想推导一下最 ...

  5. 对C++ templates类模板的几点补充(Traits类模板特化)

    前一篇文章<浅谈C++ templates 函数模板.类模板以及非类型模板参数>简单的介绍了什么是函数模板(这个最简单),类模板以及非类型模板参数.本文对类模板再做几点补充. 文章目录1. ...

  6. Linux和Windows上实现的异同-Linux的自适应ACK

    上周有同事问,延迟ACK到底对应用层会产生什么后果,我也不知道该如何作答,于是丢了一个链接: TCP之Delay ACK在Linux和Windows上实现的异同-Linux的自适应ACK: 是的,这是 ...

  7. 【TMD模拟赛】上低音号 链表

    这道题一看有两个出发现点,一枚举点去找边界,想了一会就Pass了...,二是枚举相框,我们最起码枚举两个边界,然后发现平行边界更好处理,然而仍然只有30分,这个时候就来到了链表的神奇应用,我们枚举上界 ...

  8. BZOJ 2500 幸福的道路(race) 树上直径+平衡树

    structHeal { priority_queue<int> real; priority_queue<int> stack; void push(int x){ real ...

  9. 如何在数据访问层上提高js的执行效率

    本文讲到的是如何从数据访问层面上提高JS 代码的执行效率.总的来讲有以下几条原则: 函数中读写局部变量总是最快的,而全局变量的读取则是最慢的: 尽可能地少用with 语句,因为它会增加with 语句以 ...

  10. 深入理解Java虚拟机—内存管理机制

    前面说过了类的加载机制,里面讲到了类的初始化中时用到了一部分内存管理的知识,这里让我们来看下Java虚拟机是如何管理内存的. 先让我们来看张图 有些文章中对线程隔离区还称之为线程独占区,其实是一个意思 ...