线段树

额 计蒜客竟然把这个出成noip模拟题。。。

这个东西很像1018,只不过维护的东西不太一样

具体有这五种情况,合并请看代码,自己写了一个结果wa了,然后就copy了一下。。。

然后build的时候不用把叶子结点的值赋成inf,感觉奥妙重重

#include<bits/stdc++.h>
using namespace std;
const int N = ;
int n, m;
int tree[N << ][], a[N], b[N], c[N], ans[];
void up(int &a, const int &b) { a = min(a, b); } /*
void maintain(int a[5], int l[5], int r[5], int mn, int sm)
{
memset(a, 0x3f3f3f3f, sizeof(tree[0]));
up(a[0], l[0] + r[0] + mn);
up(a[0], l[0] + r[3] + sm);
up(a[0], l[3] + r[0] + sm);
up(a[0], l[1] + r[0] + sm);
up(a[0], l[0] + r[2] + sm);
up(a[1], l[0] + r[1] + mn);
up(a[1], l[3] + r[1] + sm);
up(a[1], l[0] + r[4] + sm);
up(a[1], l[0] + r[3] + mn);
up(a[1], l[0] + r[4] + mn);
up(a[1], l[0] + r[2] + mn);
up(a[2], l[2] + r[0] + mn);
up(a[2], l[4] + r[0] + sm);
up(a[2], l[3] + a[0] + mn);
up(a[2], l[1] + r[0] + mn);
up(a[2], l[2] + r[3] + sm);
up(a[2], l[2] + r[2] + sm);
up(a[3], l[3] + r[3] + sm);
up(a[4], l[2] + r[1] + mn);
up(a[4], l[2] + r[3] + mn);
up(a[4], l[2] + r[4] + sm);
up(a[4], l[3] + r[1] + mn);
up(a[4], l[3] + r[4] + sm);
up(a[4], l[2] + r[1] + mn);
up(a[4], l[4] + r[3] + sm);
up(a[4], l[4] + r[1] + sm);
up(a[4], l[3] + r[3] + mn);
} */
void maintain(int a[] , int l[] , int r[] , int mn , int sm)
{
memset(a , 0x3f3f , sizeof(tree[])); up(a[] , l[] + r[] + mn);
up(a[] , l[] + r[] + mn);
up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + mn);
up(a[] , l[] + r[] + sm); up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + sm); up(a[] , l[] + r[] + mn);
up(a[] , l[] + r[] + mn);
up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + mn);
up(a[] , l[] + r[] + sm); up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + mn);
up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + mn);
up(a[] , l[] + r[] + sm); up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + sm);
up(a[] , l[] + r[] + sm);
} void build(int l, int r, int o)
{
if(l == r)
{
tree[o][] = c[l];
// tree[o][1] = tree[o][2] = 0x3f3f3f3f;
return;
}
int mid = (l + r) >> ;
build(l, mid, o << );
build(mid + , r, o << | );
int mn = min(a[mid], b[mid]), sm = a[mid] + b[mid];
maintain(tree[o], tree[o << ], tree[o << | ], mn, sm);
// printf("l = %d r = %d\n", l, r);
// for(int i = 0; i < 5; ++i) printf("tree[%d][%d] = %d\n", o, i, tree[o][i]);
}
void update(int l, int r, int o, int pos)
{
if(l == r)
{
tree[o][] = c[l];
return;
}
int mid = (l + r) >> ;
if(pos <= mid) update(l, mid, o << , pos);
else update(mid + , r, o << | , pos);
int mn = min(a[mid], b[mid]), sm = a[mid] + b[mid];
maintain(tree[o], tree[o << ], tree[o << | ], mn, sm);
}
bool query(int l, int r, int o, int la, int lb, int tmp[])
{
if(l > lb || r < la) return false;
if(l >= la && r <= lb)
{
for(int i = ; i < ; ++i) tmp[i] = tree[o][i];
return true;
}
int mid = (l + r) >> , tmp1[], tmp2[];
bool flag1 = query(l, mid, o << , la, lb, tmp1);
bool flag2 = query(mid + , r, o << | , la, lb, tmp2);
if(flag1 && flag2)
{
int mn = min(a[mid], b[mid]), sm = a[mid] + b[mid];
maintain(tmp, tmp1, tmp2, mn, sm);
return true;
}
if(flag1)
{
for(int i = ; i < ; ++i) tmp[i] = tmp1[i];
return true;
}
if(flag2)
{
for(int i = ; i < ; ++i) tmp[i] = tmp2[i];
return true;
}
return false;
}
int main()
{
cin >> n >> m;
for(int i = ; i < n; ++i) scanf("%d", &a[i]);
for(int i = ; i < n; ++i) scanf("%d", &b[i]);
for(int i = ; i <= n; ++i) scanf("%d", &c[i]);
build(, n, );
while(m--)
{
int x0, x1, y0, y1, w;
char opt[];
scanf("%s", opt);
if(opt[] == 'C')
{
scanf("%d%d%d%d%d", &x0, &y0, &x1, &y1, &w);
if(x0 == x1)
{
if(y0 > y1) swap(y0, y1);
if(x0 == ) a[y0] = w;
if(x0 == ) b[y0] = w;
update(, n, , y0);
update(, n, , y1);
}
if(y0 == y1)
{
c[y0] = w;
update(, n, , y0);
}
}
if(opt[] == 'Q')
{
scanf("%d%d", &y0, &y1);
query(, n, , y0, y1, ans);
printf("%d\n", ans[]);
}
}
return ;
}

bzoj3995的更多相关文章

  1. 【线段树】bzoj3995 [SDOI2015]道路修建

    线段树每个结点维护5个域: 整个区间的MST. 将两个左端点连通,两个右端点不连通,整个区间内选择2*(r-l+1)-2条边的最小生成森林,有两个连通块. 将两个右端点连通,两个左端点不连通,整个区间 ...

  2. 【BZOJ3995】[SDOI2015]道路修建 线段树区间合并

    [BZOJ3995][SDOI2015]道路修建 Description  某国有2N个城市,这2N个城市构成了一个2行N列的方格网.现在该国政府有一个旅游发展计划,这个计划需要选定L.R两列(L&l ...

  3. bzoj3995[SDOI2015]道路修建

    http://www.lydsy.com/JudgeOnline/problem.php?id=3995 线段树维护连通性. 我们发现,对于一个区间[L,R],我们只需要知道(1,L),(2,L),( ...

  4. [bzoj3995] [SDOI2015]道路修建 线段树

    Description 某国有2N个城市,这2N个城市构成了一个2行N列的方格网.现在该国政府有一个旅游发展计划,这个计划需要选定L.R两列(L<=R),修建若干条专用道路,使得这两列之间(包括 ...

随机推荐

  1. 深入理解计算机操作系统——第11章:CS模型,网络

    网络编程: 11.1 客户端-服务器编程模型 (1)一个应用是由一个服务器进程和一个或多个客户端进程组成. (2)服务器管理某种资源,并且操纵这种资源来为客户端服务. CS模型: CS的基本操作是事务 ...

  2. hdu 5195 DZY Loves Topological Sorting BestCoder Round #35 1002 [ 拓扑排序 + 优先队列 || 线段树 ]

    传送门 DZY Loves Topological Sorting Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131 ...

  3. php中memcache与memcached的区别 【收藏】

    说法一:    两个不同版本的php的memcached的客户端 new memcache是pecl扩展库版本new memcached是libmemcached版本功能差不多 说法二:    Mem ...

  4. 匿名函数--lambda函数

    匿名函数 匿名函数:为了解决一些功能很简单的需求而设计的一句话函数 (python对匿名函数支持有限,只有一些简单的条件下可以用匿名函数) 匿名函数固定格式: func = lambda *args: ...

  5. Delphi字符串加密/解密

    unit uEncrypt_Decrypt;   interface   uses SysUtils;   const XorKey: array[0..7] of Byte = ($B2, $09, ...

  6. python 爬虫(转,我使用的python3)

      原文地址:http://blog.csdn.net/pi9nc/article/details/9734437 [Python]网络爬虫(一):抓取网页的含义和URL基本构成 分类: 爬虫 Pyt ...

  7. 【.Net Core 学习系列】-- 自定义错误页面在IE浏览器中不能正常显示

    测试场景: 1. 新建.Net Core Web项目 2. 选择模板: 3. 修改Error页面代码:(去掉母版页并修改页面显示信息) 4. 修改[ASPNETCORE_ENVIRONMENT],并抛 ...

  8. Java生成验证码并进行验证(转)

    本文转自http://blog.csdn.net/worm0527/article/details/51030864 一.实现思路 使用BufferedImage用于在内存中存储生成的验证码图片 使用 ...

  9. MySQL入门笔记 - 数据类型

    参考书籍<MySQL入门很简单> 数据类型是数据的一种属性,可以决定数据的存储方式.有效范围和相应的限制. 1.整数类型   1.1 MySQL的整数类型 MySQL中int类型和inte ...

  10. volatile关键字解析&内存模型&并发编程中三概念

    原文链接: http://www.cnblogs.com/dolphin0520/p/3920373.html volatile这个关键字可能很多朋友都听说过,或许也都用过.在Java5之前,它是一个 ...