HDU 6356 Glad You Came 2018 Multi-University Training Contest 5 (线段树)
题目中没有明说会爆int和longlong 的精度,但是在RNG函数中不用unsigned int 会报精度,导致队友debug了很久...
根据每次生成的l,r,v对区间更新m次,然后求 i*ai的异或和。挺裸的线段树,只要ai<v就更新ai。在线段树结点中维护区间最小值,每次更新时,如果区间最小值>=v,那么就不用更新了。
#include<bits/stdc++.h>
#define lson rt << 1
#define rson rt << 1 | 1
#define Lson l, m, lson
#define Rson m + 1, r, rson
using namespace std;
typedef long long LL;
typedef unsigned int UI;
const int MOD = <<;
const int maxn = 1e5+;
UI X,Y,Z; LL mn[maxn<<];
void pushup(int rt) { mn[rt] = min(mn[lson],mn[rson]);} void build(int l,int r,int rt)
{
if(l==r) {
mn[rt]=;
return;
}
int m =(l+r)>>;
build(Lson);
build(Rson);
pushup(rt);
} void update(int L,int R,int l,int r,int rt,LL val)
{
if(mn[rt]>=val) return;
if(l==r){
mn[rt] = val;
return ;
}
int m =(l+r)>>;
if(L<=m) update(L,R,Lson,val);
if(R>m) update(L,R,Rson,val);
pushup(rt);
} LL query(int p,int l,int r,int rt)
{
if(l == r) return mn[rt];
int m = (l+r)>>;
if(p<=m) return query(p,Lson);
else return query(p,Rson);
} UI gao()
{
X = X^(X<<);
X = X^(X>>);
X = X^(X<<);
X = X^(X>>);
UI W = X^(Y^Z);
X = Y;
Y = Z;
Z = W;
return Z;
} int main()
{
#ifndef ONLINE_JUDGE
freopen("in.txt","r",stdin);
freopen("out.txt","w",stdout);
#endif
int T;
UI N,M;
scanf("%d",&T);
while(T--){
scanf("%u%u%u%u%u",&N,&M,&X,&Y,&Z);
build(,N,);
int l,r,v;
for(int i=;i<M;++i){
l = gao()%N +;
r = gao()%N +;
v = gao()%MOD;
if(l>r) swap(l,r);
update(l,r,,N,,v);
}
LL ans=;
for(int i=;i<=N;++i) ans ^= i*query(i,,N,);
printf("%lld\n",ans);
}
return ;
}
HDU 6356 Glad You Came 2018 Multi-University Training Contest 5 (线段树)的更多相关文章
- HDU-6315 Naive Operations//2018 Multi-University Training Contest 2___1007 (线段树,区间除法)
		原题地址 Naive Operations Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 502768/502768 K (Java/ ... 
- HDU 1611 敌兵布阵 / HRBUST 1794 敌兵布阵(线段树)
		HDU 1611 敌兵布阵 / HRBUST 1794 敌兵布阵(线段树) Description C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A ... 
- HDU 6356.Glad You Came-线段树(区间更新+剪枝) (2018 Multi-University Training Contest 5 1007)
		6356.Glad You Came 题意就是给你一个随机生成函数,然后从随机函数里确定查询的左右区间以及要更新的val值.然后最后求一下异或和就可以了. 线段树,区间最大值和最小值维护一下,因为数据 ... 
- 线段树模板(HDU 6356 Glad You Came)
		题目: HDU 6356 http://acm.hdu.edu.cn/showproblem.php?pid=6356 很裸的线段树 #include<bits/stdc++.h> #de ... 
- 2018 Arab Collegiate Programming Contest (ACPC 2018)  G. Greatest Chicken Dish (线段树+GCD)
		题目链接:https://codeforces.com/gym/101991/problem/G 题意:给出 n 个数,q 次询问区间[ li,ri ]之间有多少个 GCD = di 的连续子区间. ... 
- HDU 6141 - I am your Father!    |  2017 Multi-University Training Contest 8
		思路来自 FXXL 最小树形图模板用kuangbin的 /* HDU 6141 - I am your Father! [ 最小树形图 ] | 2017 Multi-University Traini ... 
- HDU 4946 Area of Mushroom(2014 Multi-University Training Contest 8)
		思路: 只有速度最大才有可能为1,速度不是最大肯定为0,那么就是 只需要操作那些速度最大的点,这些点求一个凸包,判断一下是不是在凸包边上即可. 有几个需要注意的地方: 1.最大速度如果为0 那么肯 ... 
- HDU 4939 Stupid Tower Defense (2014 Multi-University Training Contest 7)
		思路:首先红色肯定要放在最后面.前面蓝色和绿色dp求解. dp[i][j] 表示前面(i+j) 个 有 i 个蓝色塔 j个绿色塔 能造成最大伤害. //====================== ... 
- HDU 4913 Least common multiple(2014 Multi-University Training Contest 5)
		题意:求所有自己的最小公倍数的和. 该集合是 2^ai * 3^bi 思路:线段树. 线段树中存的是 [3^b * f(b)] f(b)表示 因子3 的最小公倍数3的部分 为 3^b的个数 ... 
随机推荐
- ArrayList和Vector的区别?
			ArrayList和Vector的区别? 解答:同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程不安全的,不是同步的:数据增长:当需要增长时,Vector默认增长为原来一 ... 
- ORM框架(对象关系映射)
			Entity Framework 学习初级篇1--EF基本概况 http://www.cnblogs.com/xray2005/archive/2009/05/07/1452033.html ORM ... 
- 2017 CCPC 杭州 流水账
			day0: 队内训练ccpc 秦皇岛,敝校自己出的题,感觉一个星期没怎么写代码,手生得很,不出意料被打飞了. day1 (热身赛): 热身赛还算顺利,A题看有的队几分钟就草过去了,还以为又是西安ICP ... 
- js for in
			JavaScript中for..in循环陷阱 大家都知道在JavaScript中提供了两种方式迭代对象: (1)for 循环: (2)for..in循环: 使用for循环进行迭代数组对象,想必 ... 
- Windows平台安装最新OpenCV-2.4.9,利用Eclipse、MinGW构建C++调用OpenCV开发环境
			近期电脑重装系统了,第一件事重装OpenCV. 这次直接装最新版,2014-4-25日公布的OpenCV2.4.9版本号,下载链接: http://sourceforge.net/projects/o ... 
- grid++report中篇
			QQ:1187362408 欢迎技术交流和学习 grid++report中篇(grid++report): TODO: 1.grid++report:简单介绍( Grid++Report 是一款高性能 ... 
- 数据库读写分离(aop方式完整实现)
			http://blog.csdn.net/machunlin2010/article/details/46471983 
- 51NOD 1013(3的幂的和)
			题目链接:传送门 题目大意:求(3^0+3^1+3^2+3^3+...+3^n)%1e9的值 题目思路:乘法逆元裸题 #include <iostream> #include <cs ... 
- [LeetCode] Factorial Trailing Zeros
			Well, to compute the number of trailing zeros, we need to first think clear about what will generate ... 
- Pycharm创建Django admin用户名和密码
			1.Tools>Run manage.py Task 2.依次输入: makemigrations migrate createsuperuser 如: manage.py@production ... 
