【HDOJ】4902 Nice boat
区间线段树。题目还不错。
/* */
#include <iostream>
#include <string>
#include <map>
#include <queue>
#include <set>
#include <vector>
#include <algorithm>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <climits>
#include <cctype>
using namespace std; #define lson l, mid, rt<<1
#define rson mid+1, r, rt<<1|1
#define MAXN 100005 typedef struct {
int mx, val;
} node_t; node_t T[MAXN<<];
int n, m, x;
int l; int gcd(int n, int m) {
if (m == )
return n;
if (m > n)
return gcd(m, n);
return gcd(m, n%m);
} void PushUp(int rt) {
T[rt].val = T[rt<<].val==T[rt<<|].val ? T[rt<<].val:-;
T[rt].mx = max(T[rt<<].mx, T[rt<<|].mx);
} void PushDown(int rt) {
if (T[rt].val >= ) {
T[rt<<].val = T[rt<<|].val = T[rt].val;
T[rt<<].mx = T[rt<<|].mx = T[rt].mx;
}
} void build(int l, int r, int rt) {
if (l == r) {
scanf("%d", &T[rt].val);
T[rt].mx = T[rt].val;
return ;
}
int mid = (l+r)>>;
build(lson);
build(rson);
PushUp(rt);
} void update1(int ll, int rr, int l, int r, int rt) {
if (ll<=l && rr>=r) {
T[rt].val = x;
T[rt].mx = x;
return ;
}
int mid = (l+r)>>;
PushDown(rt);
if (rr <= mid) {
update1(ll, rr, lson);
} else if (ll > mid) {
update1(ll, rr, rson);
} else {
update1(ll, mid, lson);
update1(mid+, rr, rson);
}
PushUp(rt);
} void update2(int ll, int rr, int l, int r, int rt) {
if (T[rt].mx <= x)
return ;
int mid = (l+r)>>;
if (ll<=l && rr>=r) {
if (T[rt].val >= ) {
T[rt].val = gcd(T[rt].val, x);
T[rt].mx = T[rt].val;
} else {
update2(ll, rr, lson);
update2(ll, rr, rson);
PushUp(rt);
}
return ;
}
PushDown(rt);
if (rr <= mid) {
update2(ll, rr, lson);
} else if (ll > mid) {
update2(ll, rr, rson);
} else {
update2(ll, mid, lson);
update2(mid+, rr, rson);
}
PushUp(rt);
} void printAll(int l, int r, int rt) {
if (T[rt].val >= ) {
for (int i=l; i<=r; ++i)
printf("%d ", T[rt].val);
return ;
}
int mid = (l+r)>>;
printAll(lson);
printAll(rson);
} int main() {
int i, j, k;
int l, r;
int t; #ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
freopen("data.out", "w", stdout);
#endif scanf("%d", &t);
while (t--) {
scanf("%d", &n);
build(, n, );
scanf("%d", &m);
while (m--) {
scanf("%d %d %d %d", &k, &l, &r, &x);
if (k == ) {
update1(l, r, , n, );
} else {
update2(l, r, , n, );
}
}
printAll(, n, );
putchar('\n');
} return ;
}
【HDOJ】4902 Nice boat的更多相关文章
- 【HDOJ】4729 An Easy Problem for Elfness
其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...
- 【HDOJ】【3506】Monkey Party
DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...
- 【HDOJ】【3516】Tree Construction
DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...
- 【HDOJ】【3480】Division
DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...
- 【HDOJ】【2829】Lawrence
DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...
- 【HDOJ】【3415】Max Sum of Max-K-sub-sequence
DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...
- 【HDOJ】【3530】Subsequence
DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...
- 【HDOJ】【3068】最长回文
Manacher算法 Manacher模板题…… //HDOJ 3068 #include<cstdio> #include<cstring> #include<cstd ...
- 【HDOJ】【1512】Monkey King
数据结构/可并堆 啊……换换脑子就看了看数据结构……看了一下左偏树和斜堆,鉴于左偏树不像斜堆可能退化就写了个左偏树. 左偏树介绍:http://www.cnblogs.com/crazyac/arti ...
随机推荐
- Google Map API v2 番外篇 关于gps位置偏差及修正方法探讨
我的手机是M35C,在我自己的map activity中,通过gps获取到的经纬度比实际地址总是有500米左右的偏差. 在网上搜索了很多,都说这个是测绘局为了保密故意弄成这样的.gps全球定位系统获得 ...
- dbartisan下载地址
http://downloads.embarcadero.com/free/dbartisan
- 初建FreeMarker工程
初建FreeMarker工程 ——@梁WP 背景:听说freemarker可以用来写页面的组件,热衷于编写可重用代码的我,迫不及待地研究了freemarker,不过,在写组件之前,还是先研究一下fre ...
- sendkeys && appactivate
sendkeys 用于输入键盘按键 appactivate 用于聚焦程序 on error resume next set ws = createObject("wscript.she ...
- python matplotlib.plot画图显示中文乱码的问题
在matplotlib.plot生成的统计图表中,中文总是无法正常显示.在网上也找了些资料,说是在程序中指定字体文件,不过那样的话需要对plot进行很多设置,而且都是说的设置坐标轴标题为中文,有时候图 ...
- JQuery判断子Iframe 加载完成的技术解决
当需要我们给当前页面动态创建Iframe子框架的时候,并且同时需要操作子Iframe里的方法的时候,我们发现无法成功实现.这是为什么呢?经小程总结,发现子Iframe还没有来的及加载完成,就去执行里面 ...
- SQL查询一些浅薄的结论
一些简单的测试结论 在本机经过一些简单的测试,记录数6W条,得出以下结论,不同的硬件环境和数据记录数,可能会有不一样的结论 1.in, or, exists, like, not in , not e ...
- ubuntu 13.04 xrdp 远程桌面连接问题[转载]
本人ubuntu12.04,遇到了同样的问题,用一下方法解决了,mark一下. ubuntu 13.04 xrdp 远程桌面连接问题. win 7 远程桌面连接 ubuntu desktop 有几种办 ...
- JAVA-线程安全性
线程安全性: 一个类是线程安全的是指在被多个线程访问时,类可以持续进行正确的行为.不用考虑这些线程运行时环境下的调度和交替. 编写正确的并发程序的关键在于对共享的,可变的状态进行访问管理. 解决方 ...
- pom.xml中<dependency>
当想下载jar包时,需要在pom.xml追加<dependency>即可. 通过如下餐叙: 如下图 http://mvnrepository.com/artifact/cglib/cgli ...