【 2017 Multi-University Training Contest - Team 9 && hdu 6162】Ch’s gift
【链接】h在这里写链接
【题意】
【题解】
【错的次数】
【反思】
【代码】
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std; const int N = 1e5; int n, m, c[N + 10], uppest[N + 10], idx[N + 10], cnt, sz[N + 10], dep[N + 10];
long long sum[(N + 10) << 2];
int mi[(N + 10) << 2], ma[(N + 10) << 2], a, b, fat[N + 10];
vector <int> g[N + 10]; void dfs1(int x, int fa) {
sz[x] = 1;
for (int y : g[x]) {
if (y == fa) continue;
dep[y] = dep[x] + 1;
dfs1(y, x);
sz[x] += sz[y];
fat[y] = x;
}
} void dfs2(int x, int chain) {
idx[x] = ++cnt;
uppest[x] = chain;
int ma = 0;
for (int y : g[x]) {
if (dep[y] > dep[x] && sz[y] > sz[ma]) {
ma = y;
}
}
if (ma == 0) return;
dfs2(ma, chain);
for (int y : g[x])
if (dep[y] > dep[x] && y != ma)
dfs2(y, y);
} void updata(int pos, int x, int l, int r, int rt) {
if (l == r) {
mi[rt] = ma[rt] = x;
sum[rt] = x;
return;
}
int m = (l + r) >> 1;
if (pos <= m)
updata(pos, x, l, m, rt << 1);
else
updata(pos, x, m + 1, r, rt << 1 | 1);
ma[rt] = max(ma[rt << 1 | 1], ma[rt << 1]);
mi[rt] = min(mi[rt << 1 | 1], mi[rt << 1]);
sum[rt] = sum[rt << 1] + sum[rt << 1 | 1];
} void pre() {
for (int i = 1; i <= n; i++)
updata(idx[i], c[i], 1, n, 1);
} long long get_ans(int L, int R, int l, int r, int rt) {
if (L <= l && r <= R) {
if (ma[rt] < a) return 0;
if (mi[rt] > b) return 0;
if (a <= mi[rt] && ma[rt] <= b) return sum[rt];
}
int m = (l + r) >> 1;
long long temp = 0;
if (L <= m)
temp += get_ans(L, R, l, m, rt << 1);
if (m < R)
temp += get_ans(L, R, m + 1, r, rt << 1 | 1);
return temp;
} long long calc(int x, int y) {
long long temp = 0;
while (uppest[x] != uppest[y]) {
if (dep[uppest[x]] > dep[uppest[y]]) swap(x, y);
//dep[x] < dep[y] ok
temp += get_ans(idx[uppest[y]], idx[y], 1, n, 1);
y = fat[uppest[y]];
}
if (dep[x] > dep[y]) swap(x, y);
temp += get_ans(idx[x], idx[y], 1, n, 1);
return temp;
} void deal() {
for (int i = 1; i <= m; i++) {
int s, t;
cin >> s >> t >> a >> b;
cout << calc(s, t);
if (i == m)
cout << endl;
else
cout << ' ';
}
} int main() {
//freopen("F:\\rush.txt", "r", stdin);
ios::sync_with_stdio(0), cin.tie(0); while (cin >> n >> m) {
for (int i = 1; i <= n; i++) cin >> c[i];
for (int i = 1; i <= n; i++) g[i].clear();
for (int i = 1; i <= n - 1; i++) {
int x, y;
cin >> x >> y;
g[x].push_back(y), g[y].push_back(x);
} dep[1] = 0;
dfs1(1, 0);
cnt = 0;
dfs2(1, 1); pre(); deal();
}
return 0;
}
【 2017 Multi-University Training Contest - Team 9 && hdu 6162】Ch’s gift的更多相关文章
- 【2017 Multi-University Training Contest - Team 7 && hdu 6121】Build a tree
[链接]点击打开链接 [题意] 询问n个点的完全k叉树,所有子树节点个数的异或总和为多少. [题解] 考虑如下的一棵k=3叉树,假设这棵树恰好有n个节点. 因为满的k叉树,第i层的节点个数为k^(i- ...
- 【HDU 6162】 Ch’s gift
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=6162 [算法] 离线树剖 我们知道,u到v路径上权值为[A,B]的数的和 = u到v路径上权值小于 ...
- 2017 Multi-University Training Contest - Team 2 &&hdu 6050 Funny Function
Funny Function Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- 2017 Multi-University Training Contest - Team 2 &&hdu 6053 TrickGCD
TrickGCD Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- 2017 Multi-University Training Contest - Team 2&&hdu 6047 Maximum Sequence
Maximum Sequence Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 2017 Multi-University Training Contest - Team 2 &hdu 6055 Regular polygon
Regular polygon Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- 【2017中国大学生程序设计竞赛 - 网络选拔赛 && hdu 6154】CaoHaha's staff
[链接]点击打开链接 [题意] 给你一个面积,让你求围成这个面积最少需要几条边,其中边的连线只能是在坐标轴上边长为1的的线或者是两个边长为1 的线的对角线. [题解] 找规律题 考虑s[i]表示i条边 ...
- 【2017中国大学生程序设计竞赛 - 网络选拔赛 hdu 6150】Vertex Cover
[链接]点击打开链接 [题意] 有人写了一个最小点覆盖的贪心算法,然后,让你去hack它. 并且,要求这个算法得到的错误答案,是正确答案的三倍. 让你任意输出hack数据,点数<=500 [题解 ...
- 2017 Multi-University Training Contest - Team 1 1006&&HDU 6038 Function【DFS+数论】
Function Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total ...
随机推荐
- 彻查网络局部网段内Ping时断时续的问题
前两天须要安装2台server,结果前期一直有问题的网络又来了,明明vlan内能ping通,可是与vlan外却ping不同. 这个现象非常像是arp病毒,于是周末的时间我们就进行了一次彻底的排查,一定 ...
- poj Transferring Sylla(怎样高速的推断一个图是否是3—连通图,求割点,割边)
Transferring Sylla 首先.什么是k连通图? k连通图就是指至少去掉k个点使之不连通的图. 题目: 题目描写叙述的非常裸.就是给你一张图要求你推断这图是否是3-连通图. 算法分析: / ...
- VS添加程序集
项目->添加->引用->程序集 可在项目的引用目录中,查看引用的程序集
- POJ 3168 排序+扫描
题意: 思路: 我们可以把每个矩形拆成四条线 与x轴平行的放在一起 与y轴平行的放在一起 排个序 判一判有没有交 有交 则说明不可扩张 统计一下 就可以了 处理的姿势很重要 姿势不对毁一生 //By ...
- c# for 和 foreach
1给定长度 不需要计算长度的 for比foreach循环效率高 2 在不确定长度 或者计算长度有性能损耗的时候 用foreach比较方便 2336 循环语句是编程的基本语句,在C#中除了沿用C语言的循 ...
- php开启openssl扩展
windows下开启方法: 1: 首先检查php.ini中:extension=php_openssl.dll是否存在, 如果存在的话去掉前面的注释符‘:’, 如果不存在这行,那么添加extensio ...
- netstat---显示Linux中网络系统的状态信息
netstat命令用来打印Linux中网络系统的状态信息,可让你得知整个Linux系统的网络情况. 语法 netstat(选项) 选项 -a或--all:显示所有连线中的Socket: -A<网 ...
- 微信小程序从零开始开发步骤(一)搭建开发环境
从零到有写一个小程序系列专题,很早以前就想写来分享,但由于项目一直在进展,没有过多的时间研究技术,现在可以继续分享了. 1:注册 用没有注册过微信公众平台的邮箱注册一个微信公众号, 申请帐号 ,网址: ...
- ActiveMQ学习总结(2)——ActiveMQ入门实例教程
1.下载ActiveMQ 去官方网站下载:http://activemq.apache.org/ 2.运行ActiveMQ 解压缩apache-activemq-5.5.1-bin.zip,然后双击a ...
- 47.Android 自己定义PopupWindow技巧
47.Android 自己定义PopupWindow技巧 Android 自己定义PopupWindow技巧 前言 PopupWindow的宽高 PopupWindow定位在下左位置 PopupWin ...