HDU 6356 (线段树-l,r 之间小于val 的变val+单点求值)
题目描述:
给你一个长度为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+单点求值)的更多相关文章
- hdu 5124(区间更新+单点求值+离散化)
lines Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- 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< ...
- hdu 3436 线段树 一顿操作
Queue-jumpers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) To ...
- hdu 3397 线段树双标记
Sequence operation Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 1542 线段树扫描(面积)
Atlantis Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- hdu 1828 线段树扫描线(周长)
Picture Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...
- hdu 3954 线段树 (标记)
Level up Time Limit: 10000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- HDU 4902 (线段树)
Problem Nice boat(HDU 4902) 题目大意 维护一个序列,两种操作. 第一种操作,将一段区间[l,r]赋值为x. 第二种操作,将一段区间[l,r]中大于等于x的数与x求gcd. ...
- 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 ...
随机推荐
- 246. Strobogrammatic Number 上下对称的数字
[抄题]: A strobogrammatic number is a number that looks the same when rotated 180 degrees (looked at u ...
- Mybatis中resultType和resultMap
一.概述MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,resultType是直接表示返回类型的,而resultMap则是对外部Res ...
- Django框架 之 查询 Extra
Django框架 之 查询 Extra extra 1 2 extra(select=None, where=None, params=None, tables=None, order_b ...
- 利用 Aspose.Words 组件,在不依赖与 Office 组件的情况下把 Word 文件转换成 HTML 代码。
首先利用 Nuget 获取 Aspose.Words.dll public ActionResult AsposeWordsDemo() { string srcFileName = Server.M ...
- Python Lambda 的简单用法
下面代码简单举例介绍以下 lambda的用法. from functools import reduce #1 python lambda会创建一个函数对象,但不会把这个函数对象赋给一个标识符,而de ...
- 301 MovedPermanently 重定向
页面永久性移走(301重定向)是一种非常重要的“自动转向”技术. 301重定向可促进搜索引擎优化效果 从搜索引擎优化角度出发,301重定向是网址重定向最为可行的一种办法.当网站的域名发生变更后,搜索引 ...
- Server Sql 多表查询、子查询和分页
一.多表查询:根据特定的连接条件从不同的表中获取所需的数据 多表查询语法: SELECT table1.column, table2.column FROM table1, table2 WHERE ...
- Java并发编程的3个特性
一.原子性 原子行:即一个或者多个操作作为一个整体,要么全部执行,要么都不执行,并且操作在执行过程中不会被线程调度机制打断:而且这种操作一旦开始,就一直运行到结束,中间不会有任何上下文切换(conte ...
- javascript framework js常用框架
js常用框架 一.node.js 二.angularjs.js 三.react.js 四.webpack.js 五.flux.js 六.vue.js 七.bootstrap ...
- 指针和动态分配内存 (不定长度数组)------新标准c++程序设计
背景: 数组的长度是定义好的,在整个程序中固定不变.c++不允许定义元素个数不确定的数组.例如: int n; int a[n]; //这种定义是不允许的 但是在实际编程中,往往会出现要处理的数据数量 ...