题目描述:

给你一个长度为n的最开始为0的数以及m个更新操作以及数据生成器参数X,Y,Z。每次操作,将由数据生成器生成出li,ri,vi。让你从区间[li,ri]中,将所有小于vi的数变为vi。最后让你求从1到n的 i*ai的亦或和。

分析:区间操作优先考虑线段树 , 那线段树存储什么数值呢? 我们知道如果l ,r 的最大值<=val , 那整个l区间都要改成val , 如果最小值>=val  那这个区间就不用修改 ; 那不是这种情况怎么办呢?不可能是for一遍吧 , 其实只要一次跟新操作就好 , 线段树的区间更新是将整课树都遍历一遍 ,所以我们只要在遍历的过程中判断是否到达叶子结点就好拉;

#include <iostream>
#include <string.h>
#include <algorithm>
#include <stdio.h>
#include <math.h>
#include <queue>
#define MAXN 5000001
#define inf 0x3f3f3f3f using namespace std;
unsigned int x,y,z,w,v,b[MAXN*];
int n,m;
long long ans;
unsigned int fun()
{
x=x^(x<<);
x=x^(x>>);
x=x^(x<<);
x=x^(x>>);
w=x^(y^z);
x = y ; y = z ; z = w;
return z;
}
struct node{
int l,r;//区间[l,r]
int add;//区间的延时标记
int mx; //区间最大值
int mn; //区间最小值
}tree[MAXN<<];//一定要开到4倍多的空间 void pushup(int index){
tree[index].mx = max(tree[index<<].mx,tree[index<<|].mx);
tree[index].mn = min(tree[index<<].mn,tree[index<<|].mn);
}
void pushdown(int index){
//说明该区间之前更新过
//要想更新该区间下面的子区间,就要把上次更新该区间的值向下更新
if(tree[index].add > ){
//替换原来的值 tree[index<<].mx = tree[index].add;
tree[index<<|].mx = tree[index].add;
tree[index<<].mn = tree[index].add;
tree[index<<|].mn = tree[index].add;
tree[index<<].add = tree[index].add;
tree[index<<|].add = tree[index].add;
tree[index].add = ; }
}
void build(int l,int r,int index){
tree[index].l = l;
tree[index].r = r;
tree[index].add = ;//刚开始一定要清0
if(l == r){ tree[index].mn = tree[index].mx = ;
return ;
}
int mid = (l+r)>>;
build(l,mid,index<<);
build(mid+,r,index<<|);
pushup(index);
}
void updata(int l,int r,int index,int val){ if(tree[index].l==tree[index].r)///到达叶子节点
{
tree[index].mn=max(tree[index].mn , val);
tree[index].mx=max(tree[index].mx , val);
return ;
}
if(l <= tree[index].l && r >= tree[index].r){ if(tree[index].mx<=val)
{
tree[index].mn = val;
tree[index].mx = val;
tree[index].add = val;//延时标记
return ;
}
if(tree[index].mn>=val) return ;
}
if(tree[index].mn>=val) return ;
pushdown(index);
int mid = (tree[index].l+tree[index].r)>>;
if(l <= mid){
updata(l,r,index<<,val);
}
if(r > mid){
updata(l,r,index<<|,val);
}
pushup(index);
}
int query(int l,int r,int index,int pos){
if(l==r)
{
return tree[index].mn;
}
int mid=(l+r)>>;
pushdown(index);
if(pos<=mid) return query(l,mid , index<< , pos);
else return query(mid+,r ,index<<| , pos);
}
int main()
{ int t,l,r;
scanf("%d",&t);
while(t--)
{
scanf("%d%d%u%u%u",&n , &m , &x , &y , &z);
build(,n,);
for(int i= ; i<=max(n,*m) ; i++)///数据生成器
b[i] = fun();
for(int i= ; i<=m ; i++)
{
l = min(b[*i-]%n+ , b[*i-]%n+);
r = max(b[*i-]%n+ , b[*i-]%n+);
v = b[*i]%(<<);
updata(l,r,,v);
}
ans=;
for(int i= ; i<=n ; i++)
ans^=(long long)i*query(,n,,i);
printf("%lld\n",ans);
} return ;
}

HDU 6356 (线段树-l,r 之间小于val 的变val+单点求值)的更多相关文章

  1. hdu 5124(区间更新+单点求值+离散化)

    lines Time Limit: 5000/2500 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  2. UPC 2224 Boring Counting (离线线段树,统计区间[l,r]之间大小在[A,B]中的数的个数)

    题目链接:http://acm.upc.edu.cn/problem.php?id=2224 题意:给出n个数pi,和m个查询,每个查询给出l,r,a,b,让你求在区间l~r之间的pi的个数(A< ...

  3. hdu 3436 线段树 一顿操作

    Queue-jumpers Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) To ...

  4. hdu 3397 线段树双标记

    Sequence operation Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  5. hdu 1542 线段树扫描(面积)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  6. hdu 1828 线段树扫描线(周长)

    Picture Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  7. hdu 3954 线段树 (标记)

    Level up Time Limit: 10000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  8. HDU 4902 (线段树)

    Problem Nice boat(HDU 4902) 题目大意 维护一个序列,两种操作. 第一种操作,将一段区间[l,r]赋值为x. 第二种操作,将一段区间[l,r]中大于等于x的数与x求gcd. ...

  9. hdu 5877 线段树(2016 ACM/ICPC Asia Regional Dalian Online)

    Weak Pair Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

随机推荐

  1. Java-Decimal

    import java.math.BigDecimal; import java.text.DecimalFormat; import java.text.NumberFormat; public c ...

  2. SQL SERVER 2008权限配置

    我要的结果是这样:只能有查询表的权限,而且还要有运行SQL Server Profiler的权限.这样才能跟踪发现问题,当然解决问题是另外一回事,即不能有修改和更新存储过程的权限. 我在分配角色成员时 ...

  3. Mask_RCNN训练模型初步测试结果

    调用训练的模型,加载测试集,发现测试效果并不理想,所以,需要调整训练参数,继续训练模型

  4. 2-python代码坑点

    #切片: # L = ['aaa', 'bbb', 'ccc', 'ddd'] # print(L[1 : 3]) #取[1, 3):下标 # L = list(range(100)) # print ...

  5. 第十二课 Actionlib(1)

    一\Actionlib概念 在ROS系统中,有时需发送请求给某个节点完成相应的任务,同时获得一个一个响应,这种情况下可以通过ROS服务来 完成;然而,在某些情况下,服务需要很长时间才能执行完,如让机器 ...

  6. 2.2开源的魅力:编译opencv源代码

    1.下载安装CMake 要在Windows平台下生成opencv的解决方案,需要一个名为CMake的开源软件.CMake的全称是crossplatform make.它是一个跨平台的安装(编译)工具, ...

  7. Spark的job调优(1)

    本文翻译之cloudera的博客,本系列有两篇,第二篇看心情了 概论 当我们理解了transformation,action和rdd后,我们就可以写一些基础的spark的应用了,但是如果需要对应用进行 ...

  8. JavaScript判断是否是数组

    在 ECMAScript5中定义了一个新的方法Array.isArray(). 如果参数是数组的话,就返回true eg: Array.isArray([]); // true 如果里面换一个类似数组 ...

  9. js选择文件夹路径

    该方法只支持IE. 语法:strDir=Shell.BrowseForFolder(Hwnd,Title,Options,[RootFolder])参数:Hwnd:包含对话框的窗体句柄(handle) ...

  10. js-简单的作业

    作业 1 将课堂 偶数奇数和 猜数字游戏 电话银行转for循环 2 编写 “个人所得税计算器”函数 10000 计算个税的方法: 3500 以下免征 6500 3500 ~ 5000 部分 缴纳 3% ...