HDU 4902 (线段树)
Problem Nice boat(HDU 4902)
题目大意
维护一个序列,两种操作。
第一种操作,将一段区间[l,r]赋值为x。
第二种操作,将一段区间[l,r]中大于等于x的数与x求gcd。
询问所有操作结束后的序列。
解题分析
用线段树开一个标记same,表示这段区间中的数是否相同,若相同则为该数,否则为-1。
对于第二种操作,对于覆盖区间内的same不为-1的子区间暴力修改。
虽然时限有15s,但貌似跑得挺快的,只用了1s,不知是数据水还是什么缘故。
参考程序
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std; #define N 100008
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
int same[N*];
int n; int gcd(int x,int y){
return y ? gcd(y,x % y): x;
} void pushup(int rt){
if (same[rt<<]==same[rt<<|]) same[rt]=same[rt<<];
else same[rt]=-;
} void pushdown(int rt){
if (~same[rt]){
same[rt<<]=same[rt<<|]=same[rt];
same[rt]=-;
}
} void build(int l,int r,int rt){
same[rt]=-;
if (l==r){
scanf("%d",&same[rt]);
return;
}
int m=(l+r) / ;
build(lson);
build(rson);
pushup(rt);
} void update_1(int L,int R,int val,int l,int r,int rt){
if (L<=l && r<=R){
same[rt]=val;
return;
}
pushdown(rt);
int m=(l+r) /;
if (L<=m) update_1(L,R,val,lson);
if (m< R) update_1(L,R,val,rson);
pushup(rt);
} void update_2(int L,int R,int val,int l,int r,int rt){
if (L<=l && r<=R){
if (~same[rt]){
if (same[rt]>=val) same[rt]=gcd(same[rt],val);
return;
}
}
pushdown(rt);
int m=(l+r) /;
if (L<=m) update_2(L,R,val,lson);
if (m< R) update_2(L,R,val,rson);
pushup(rt);
} void query(int l,int r,int rt){
if (l==r){
printf("%d ",same[rt]);
return;
}
pushdown(rt);
int m=(l+r) / ;
query(lson);
query(rson);
} int main(){
int T;
scanf("%d",&T);
while (T--){
scanf("%d",&n);
build(,n,);
int type,a,b,val,q;
scanf("%d",&q);
while (q--){
scanf("%d %d %d %d",&type,&a,&b,&val);
if (type==) update_1(a,b,val,,n,);
if (type==) update_2(a,b,val,,n,);
}
query(,n,);
printf("%\n");
}
}
HDU 4902 (线段树)的更多相关文章
- hdu 4902 线段树+逆向模拟
http://acm.hdu.edu.cn/showproblem.php?pid=4902 出n个数,然后对这n个数进行两种操作: 如果是 1 l r x,则把 [l, r] 区间里面的每一个数都变 ...
- 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 ...
- hdu 3974 线段树 将树弄到区间上
Assign the task Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 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 4578 线段树(标记处理)
Transformation Time Limit: 15000/8000 MS (Java/Others) Memory Limit: 65535/65536 K (Java/Others) ...
- hdu 4533 线段树(问题转化+)
威威猫系列故事——晒被子 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Tot ...
- hdu 2871 线段树(各种操作)
Memory Control Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
- hdu 4052 线段树扫描线、奇特处理
Adding New Machine Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
随机推荐
- 231. Power of Two 342. Power of Four -- 判断是否为2、4的整数次幂
231. Power of Two Given an integer, write a function to determine if it is a power of two. class Sol ...
- maven install 时提示“程序包 javax.crypto不存在”
但是javax.crypto是在jdk的jre\lib目录下的 解决方案: <compilerArguments> <bootclasspath>${java.home}/li ...
- 报错解决:No Hibernate Session bound to thread, and configuration does not allow creation of non-transactional one here
大概分析一般使用了注解才会报这方面的错 1.没有在spring的ApplicationContext.xml中开启注解事务 <!-- 开启注解事务 --> <tx:annotatio ...
- Lambda表达式与Function接口
Lambda表达式是一个匿名函数.C++ 11和 java 8 相继引入了有关对Lambda表达式的支持. Lambda表达式对于高级语言而言并不是必要的,对于Java而言它的功能和一个简易的接口差不 ...
- F-Dining Cows(POJ 3671)
Dining Cows Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7584 Accepted: 3201 Descr ...
- BZOJ3058 四叶草魔杖
Poetize11的T3 蒟蒻非常欢脱的写完了费用流,发现...边的cost竟然只算一次!!! 然后就跪了... Orz题解:"类型:Floyd传递闭包+最小生成树+状态压缩动态规划首先Fl ...
- 600万用户数据导入MYSQL、MSSQL、Oracle数据库方法【转】
1.导入MySql数据库 参考文献:http://zhuaxia.org/blog/post/145 1.1.LOAD DATA INFILE语法 因为获得的数据库文件是一个文本文件www.csd ...
- [Js]基础知识
一.JavaScript组成 1.ECMAScript 解释器.翻译(提供功能有限,如加减乘除,定义变量.函数等) 几乎没有兼容性问题 2.DOM 有一些兼容性问题 3.BOM(用的少,交互 ...
- Sticks(poj1011/uva307)
题目大意: 乔治有一些碎木棒,是通过将一些相等长度的原始木棒折断得到的,给出碎木棒的总数和各自的长度,求最小的可能的原始木棒的长度:(就是将一些正整数分组,每组加起来和相等,使和尽可能小) 一开始做p ...
- ubuntu连接Android调试
从这周开始尝试Android开发,记下点滴. 安装JDK.下载ADT不说,连接手机调试的时候出错,一堆问号??????????.网上一查,属于典型错误.试下来,有几步比较关键,容易忽视: 1.我机器上 ...