HDU-6356 Glad You Came 线段树 ST表
题意:有m次操作,每次操作通过给定的随机函数生成 l , r , v,使得在 l 到 r 区间内,所有的a【i】变为max(a[i] , v).
最后输出n个a【i】* i的异或和。
思路:线段树操作,每次维护区间的最小值,如果当前的v小于区间的最小值,直接return,lazy标记维护区间未加的最大值,必要时pushdown就ok;
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <string>
#include <vector>
#include <map>
#include <set>
#include <queue>
#include <list>
#include <cstdlib>
#include <iterator>
#include <cmath>
#include <iomanip>
#include <bitset>
#include <cctype>
using namespace std;
//#pragma comment(linker, "/STACK:102400000,102400000") //c++
#define lson (l , mid , rt << 1)
#define rson (mid + 1 , r , rt << 1 | 1)
#define debug(x) cerr << #x << " = " << x << "\n";
#define pb push_back
#define pq priority_queue typedef long long ll;
typedef unsigned long long ull; typedef pair<ll ,ll > pll;
typedef pair<int ,int > pii; //priority_queue<int> q;//这是一个大根堆q
//priority_queue<int,vector<int>,greater<int> >q;//这是一个小根堆q
#define fi first
#define se second
// #define endl '\n' #define OKC ios::sync_with_stdio(false);cin.tie(0)
#define FT(A,B,C) for(int A=B;A <= C;++A) //用来压行
#define REP(i , j , k) for(int i = j ; i < k ; ++i)
//priority_queue<int ,vector<int>, greater<int> >que; const ll mos = 0x7FFFFFFF; //
const ll nmos = 0x80000000; //-2147483648
const int inf = 0x3f3f3f3f;
const ll inff = 0x3f3f3f3f3f3f3f3f; // template<typename T>
inline T read(T&x){
x=;int f=;char ch=getchar();
while (ch<''||ch>'') f|=(ch=='-'),ch=getchar();
while (ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x=f?-x:x;
}
// #define _DEBUG; //*//
#ifdef _DEBUG
freopen("input", "r", stdin);
// freopen("output.txt", "w", stdout);
#endif
/*-----------------------show time----------------------*/
unsigned X,Y,Z,W;
unsigned RNG61(){
X = X ^ (X<<);
X = X ^ (X>>);
X = X ^ (X<<);
X = X ^ (X>>);
W = X ^ (Y ^ Z);
X = Y;
Y = Z;
Z = W;
return Z;
} const ll MOD = (<<);
const int maxn = 1e5+;
int n,m; ll sum[maxn*],lazy[maxn*];
void build(int l,int r,int rt){
sum[rt] = ;
lazy[rt] = ;
if(l==r){
return;
}
int mid = (l + r)/;
build(l,mid,rt<<);
build(mid+,r,rt<<|);
}
void pushup(int rt){
sum[rt] = min(sum[rt<<] , sum[rt<<|]);
}
void pushdown(int rt){
if(lazy[rt]){
lazy[rt<<] = max(lazy[rt],lazy[rt<<]);
lazy[rt<<|] = max(lazy[rt],lazy[rt<<|]);
sum[rt<<] = max(sum[rt<<] , lazy[rt]);
sum[rt<<|] = max(sum[rt<<|] , lazy[rt]);
lazy[rt] = ;
}
}
void update(int l, int r, int rt,int L,int R,ll val){
if(sum[rt] > val)return;
if(l>=L && r <=R){ sum[rt] = max(sum[rt],val); lazy[rt] = max(lazy[rt],val);
return;
}
pushdown(rt);
int mid = (l+r)/;
if(mid >= L)update(l,mid,rt<<,L,R,val);
if(mid < R)update(mid+,r, rt<<|, L,R,val);
pushup(rt);
}
ll ans = 0ll;
void g_ans(int l,int r,int rt,int L,int R){
if(l==r){
// debug(sum[rt]);
ans ^= (1ll*l*sum[rt]);
return;
}
pushdown(rt);
int mid = (l+r)/;
g_ans(l,mid,rt<<,L,R);
g_ans(mid+,r, rt<<|, L,R);
}
int main(){
int t; scanf("%d", &t);
while(t--){ scanf("%d%d", &n, &m);
scanf("%u%u%u", &X, &Y, &Z);
build(,n,);
// debug(X);
for(int i=; i<=m; i++){
ll s = RNG61();
ll t = RNG61();
int tmp1 = s%n+;
int tmp2 = t%n+; int le = min(tmp1 , tmp2);
int ri = max(tmp1, tmp2);
ll v = RNG61() % MOD;
update(,n,,le,ri,v);
}
ans = 0ll;
g_ans(,n,,,n);
printf("%lld\n", ans);
} return ;
}
线段树
由于询问只有一次,就是最后的输出,所以可以用ST表,这道题算是一个逆向的构造ST表,推出dp【0】【i】的结果;
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <string>
#include <vector>
#include <map>
#include <set>
#include <queue>
#include <list>
#include <cstdlib>
#include <iterator>
#include <cmath>
#include <iomanip>
#include <bitset>
#include <cctype>
#include <iostream>
using namespace std;
//#pragma comment(linker, "/STACK:102400000,102400000") //c++
#define lson (l , mid , rt << 1)
#define rson (mid + 1 , r , rt << 1 | 1)
#define debug(x) cerr << #x << " = " << x << "\n";
#define pb push_back
#define pq priority_queue typedef long long ll;
typedef unsigned long long ull; typedef pair<ll ,ll > pll;
typedef pair<int ,int > pii; //priority_queue<int> q;//这是一个大根堆q
//priority_queue<int,vector<int>,greater<int> >q;//这是一个小根堆q
#define fi first
#define se second
// #define endl '\n' #define OKC ios::sync_with_stdio(false);cin.tie(0)
#define FT(A,B,C) for(int A=B;A <= C;++A) //用来压行
#define REP(i , j , k) for(int i = j ; i < k ; ++i)
//priority_queue<int ,vector<int>, greater<int> >que; const ll mos = 0x7FFFFFFF; //
const ll nmos = 0x80000000; //-2147483648
const int inf = 0x3f3f3f3f;
const ll inff = 0x3f3f3f3f3f3f3f3f; // template<typename T>
inline T read(T&x){
x=;int f=;char ch=getchar();
while (ch<''||ch>'') f|=(ch=='-'),ch=getchar();
while (ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x=f?-x:x;
}
// #define _DEBUG; //*//
#ifdef _DEBUG
freopen("input", "r", stdin);
// freopen("output.txt", "w", stdout);
#endif
/*-----------------------show time----------------------*/
unsigned X,Y,Z,W;
unsigned RNG61(){
X = X ^ (X<<);
X = X ^ (X>>);
X = X ^ (X<<);
X = X ^ (X>>);
W = X ^ (Y ^ Z);
X = Y;
Y = Z;
Z = W;
return Z;
} const ll MOD = (<<);
const int maxn = 1e5+;
int n,m; ll dp[][maxn];
int Log[maxn];
void update(int le,int ri,ll val){
int k = Log[ri-le+];
dp[k][le] = max(dp[k][le], val);
dp[k][ri-(<<k)+] = max(val,dp[k][ri-(<<k)+]);
}
void solve(){
cin>>n>>m>>X>>Y>>Z;
for(int j=; j<;j++){
for(int i=; i<=n; i++){
dp[j][i] = ;
}
} for(int i=; i<=m; i++){
int t1 = RNG61()%n + ;
int t2 = RNG61()%n + ;
int le = min(t1, t2);
int ri = max(t1, t2);
ll val = RNG61() % MOD; update(le,ri,val);
// cout<<val<<endl;
} for(int j=; j; j--){
for(int i=; i+(<<(j-)) <=n; i++){
dp[j-][i] = max(dp[j][i] , dp[j-][i]);
dp[j-][i+(<<(j-))] = max(dp[j-][i+(<<(j-))] ,dp[j][i]);
}
} ll ans = ;
for(int i=; i<=n; i++){
ans = ans ^ (i * dp[][i]);
// cout<<dp[0][i]<<" ";
}
// cout<<endl;
cout<<ans<<endl;
} int main(){
OKC;
Log[] = ;
for(int i=; i<maxn; i++){
Log[i] = Log[i>>] + ;
}
int t; cin>>t; while(t--){
solve();
}
return ;
}
ST表
HDU-6356 Glad You Came 线段树 ST表的更多相关文章
- HDU 6356.Glad You Came-线段树(区间更新+剪枝) (2018 Multi-University Training Contest 5 1007)
6356.Glad You Came 题意就是给你一个随机生成函数,然后从随机函数里确定查询的左右区间以及要更新的val值.然后最后求一下异或和就可以了. 线段树,区间最大值和最小值维护一下,因为数据 ...
- 51Nod.1766.树上最远点对(树的直径 RMQ 线段树/ST表)
题目链接 \(Description\) 给定一棵树.每次询问给定\(a\sim b,c\sim d\)两个下标区间,从这两个区间中各取一个点,使得这两个点距离最远.输出最远距离. \(n,q\leq ...
- luoguP5108 仰望半月的夜空 [官方?]题解 后缀数组 / 后缀树 / 后缀自动机 + 线段树 / st表 + 二分
仰望半月的夜空 题解 可以的话,支持一下原作吧... 这道题数据很弱..... 因此各种乱搞估计都是能过的.... 算法一 暴力长度然后判断判断,复杂度\(O(n^3)\) 期望得分15分 算法二 通 ...
- CF803G-Periodic RMQ Problem【离散化,线段树,ST表】
正题 题目链接:https://www.luogu.com.cn/problem/CF803G 题目大意 一个长度为\(n\)的序列\(a\)复制\(k\)份连接,要求支持 区间赋值 区间查询最小值 ...
- 线段树模板(HDU 6356 Glad You Came)
题目: HDU 6356 http://acm.hdu.edu.cn/showproblem.php?pid=6356 很裸的线段树 #include<bits/stdc++.h> #de ...
- HDU 3016 Man Down (线段树+dp)
HDU 3016 Man Down (线段树+dp) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- HDU.5692 Snacks ( DFS序 线段树维护最大值 )
HDU.5692 Snacks ( DFS序 线段树维护最大值 ) 题意分析 给出一颗树,节点标号为0-n,每个节点有一定权值,并且规定0号为根节点.有两种操作:操作一为询问,给出一个节点x,求从0号 ...
- HDU.1556 Color the ball (线段树 区间更新 单点查询)
HDU.1556 Color the ball (线段树 区间更新 单点查询) 题意分析 注意一下pushdown 和 pushup 模板类的题还真不能自己套啊,手写一遍才行 代码总览 #includ ...
- HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)
HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...
随机推荐
- Java编程基础阶段笔记 day04 Java基础语法(下)
day04 Java基础语法 (下) 笔记Notes要点 switch-case语句注意 switch-case题目(switchTest5) 循环执行顺序 if-else 实现3个整数排序 Stri ...
- 你了解HTTPS,但你可能不了解X.509
世上根本就没有HTTPS协议,只有HTTP协议.——知乎某答友 某天,收到领导指示:学习一下X.509相关原理. 很多开发者可能和我一样觉得X.509这个词很陌生,但其实我们经常和它打交道,属于典型的 ...
- 第十章 Fisco Bcos 权限控制下的数据上链实操演练
一.目的 前面已经完成fisco bcos 相关底层搭建.sdk使用.控制台.webase中间件平台等系列实战开发, 本次进行最后一个部分,体系化管理区块链底层,建立有序的底层控管制度,实现权限化管理 ...
- JDK1.8源码分析01之学习建议(可以延伸其他源码学习)
序言:目前有个计划就是准备看一下源码,来提升自己的技术实力.同时现在好多面试官都喜欢问源码,问你是否读过JDK源码等等? 针对如何阅读源码,也请教了我的老师.下面就先来看看老师的回答,也许会有帮助呢. ...
- Spring浅入浅出——不吹牛逼不装逼
Spring浅入浅出——不吹牛逼不装逼 前言: 今天决定要开始总结框架了,虽然以前总结过两篇,但是思维是变化的,而且也没有什么规定说总结过的东西就不能再总结了,是吧.这次总结我命名为浅入浅出,主要在于 ...
- 安装CUDA9.0及对应版本的tensorflow-gpu详细过程(Windows server 2012R2版本也可以)
由于最近跑机器学习相关代码的时候CPU运算速度跟不上,这才利用GPU来运算代码,显然使用GPU来运算速度明显要快很多,但是搭配GPU的使用环境是真的麻烦且头疼.网上有很多牛人的搭建过程,虽然他们都成功 ...
- 什么是Singleton?
Singleton:在Java中即指单例设计模式,它是软件开发中最常用的设计模式之一. 单:指唯一 例:指实例 单例设计模式,即某个类在整个系统中只能有一个实例对象可被获取和使用的代码模式. 要点: ...
- Go中的日志及第三方日志包logrus
有别的语言使用基础的同学工作中都会接触到日志的使用,Go中自然也有log相关的实现.Go log模块主要提供了3类接口,分别是 "Print .Panic .Fatal ",对每一 ...
- (四)c#Winform自定义控件-选择按钮组
前提 入行已经7,8年了,一直想做一套漂亮点的自定义控件,于是就有了本系列文章. 开源地址:https://gitee.com/kwwwvagaa/net_winform_custom_control ...
- hadoop2.7之作业提交详解(上)
根据wordcount进行分析: import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.Path; impo ...