BZOJ 3365 Distance Statistics 点分治
这道题是一道点分治的题目,难度不大,可以拿来练手。
关键是对于找出来的重心的删除操作需要删掉这条边,这很重要。
还有每次找重心的时候,不但要考虑他的子节点的siz,还要考虑父节点的siz。
然后就A了。。。
每次点分治 分两种情况讨论一下就可以啦!
/w\...
#include <cstdio>
#include <algorithm> using namespace std; const int maxn = 56789;
const int INF = 1000000007; int getint()
{
int r = 0, k = 1;
char c;
for (c = getchar(); c < '0' || c > '9'; c = getchar() ) if (c == '-') k = -1;
for (; '0' <= c && c <= '9'; c = getchar() ) r = r * 10 - '0' + c;
return r * k;
} int n, m, k;
int h[maxn], siz[maxn]; struct edge_type
{
int v, next, w;
bool baned;
} edge[maxn * 2]; int tote = 0; void ins(int u, int v, int w)
{
edge[++tote].v = v;
edge[tote].next = h[u];
edge[tote].w = w;
edge[tote].baned = false;
h[u] = tote;
} int fgans, fgsiz; void get_fgans(int now, int fa, int size) {
int tmp = 1;
siz[now] = 1;
for (int i = h[now]; i; i = edge[i].next) {
if (!edge[i].baned && fa != edge[i].v) {
get_fgans(edge[i].v, now, size);
siz[now] += siz[edge[i].v];
if (tmp < siz[edge[i].v]) tmp = siz[edge[i].v];
}
}
if (tmp < size - siz[now]) tmp = size - siz[now];
if (tmp < fgsiz) {
fgans = now;
fgsiz = tmp;
}
}
int find_gravity(int rt, int size) {
fgsiz = INF;
fgans = rt;
get_fgans(rt, -1, size);
return fgans;
} int dis[maxn];
int zhan[maxn], zcnt; void get_dis(int now, int nd, int fa) {
dis[now] = nd;
for (int i = h[now]; i; i = edge[i].next)
if (!edge[i].baned && fa != edge[i].v)
get_dis(edge[i].v, nd + edge[i].w, now);
} void dfs(int now, int fa) {
zhan[++zcnt] = dis[now];
for (int i = h[now]; i; i = edge[i].next)
if (!edge[i].baned && fa != edge[i].v)
dfs(edge[i].v, now);
} int calculate(int rt) {
int ret = 0;
zcnt = 0;
dfs(rt, -1);
sort(zhan + 1, zhan + zcnt + 1);
for (int i = 1, j = zcnt; i <= zcnt; ++i) {
for (; j && zhan[i] + zhan[j] > k; --j);
ret += j;
}
return ret;
} int Ans = 0; void dfz(int now, int size)
{
int rt = find_gravity(now, size);
get_dis(rt, 0, -1);
Ans += calculate(rt);
int v;
for (int i = h[rt]; i; i = edge[i].next)
if (!edge[i].baned) {
edge[i].baned = edge[((i-1)^1)+1].baned = true;
Ans -= calculate(edge[i].v);
dfz(edge[i].v, siz[edge[i].v]);
}
} int main()
{
n = getint();
m = getint();
int u, v, w;
for (int i = 1; i < n; ++i)
{
u = getint();
v = getint();
w = getint();
ins (u, v, w);
ins (v, u, w);
}
k = getint();
dfz(1, n);
printf("%d", (Ans - n >> 1));
return 0;
}
BZOJ 3365 Distance Statistics 点分治的更多相关文章
- POJ 1987 BZOJ 3365 Distance Statistics 树的分治(点分治)
题目大意:(同poj1741,刷一赠一系列) CODE: #include <cstdio> #include <cstring> #include <iostream& ...
- [BZOJ 3365] Distance Statistics
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=3365 [算法] 点分治 [代码] #include <algorithm> ...
- POJ 1987 Distance Statistics 树分治
Distance Statistics Description Frustrated at the number of distance queries required to find a ...
- BZOJ_3365_[Usaco2004 Feb]Distance Statistics 路程统计&&POJ_1741_Tree_点分治
BZOJ_3365_[Usaco2004 Feb]Distance Statistics 路程统计&&POJ_1741_Tree_点分治 Description 在得知了自己农 ...
- BZOJ.4184.shallot(线段树分治 线性基)
BZOJ 裸的线段树分治+线性基,就是跑的巨慢_(:з」∠)_ . 不知道他们都写的什么=-= //41652kb 11920ms #include <map> #include < ...
- [BZOJ 4025]二分图(线段树分治+带边权并查集)
[BZOJ 4025]二分图(线段树分治+带边权并查集) 题面 给出一个n个点m条边的图,每条边会在时间s到t出现,问每个时间的图是否为一个二分图 \(n,m,\max(t_i) \leq 10^5\ ...
- bzoj 3365 [Usaco2004 Feb]Distance Statistics 路程统计(点分治,单调)
[题意] 求树上长度不超过k的点对数目. [思路] 和 Tree 一样一样的. 就是最后统计的时候别忘把根加上. [代码] #include<set> #include<cmath& ...
- bzoj 3365: [Usaco2004 Feb]Distance Statistics 路程统计【容斥原理+点分治】
统计在一个root下的两个子树,每个子树都和前面的运算一下再加进去对于这种需要排序的运算很麻烦,所以考虑先不去同子树内点对的算出合法点对个数,然后减去每一棵子树内的合法点对(它们实际上是不合法的,相当 ...
- BZOJ 3365: [Usaco2004 Feb]Distance Statistics 路程统计
Description 一棵树,统计距离不大于 \(k\) 的点对个数. Sol 点分治. 发现自己快把点分治忘干净了... 找重心使所有儿子的最大值尽量小,然后每次处理全部子树,再减去每个子树的贡献 ...
随机推荐
- Java 读写XML
package dome4jTest; import java.io.FileWriter; import java.io.IOException; import java.net.URL; impo ...
- Android笔记:通知
可以在活动里创建,也可以在广播接收器里创建,还可以在服务里创建. NotificationManager manager = (NotificationManager)getSystemService ...
- Spring实例化Bean的三种方式及Bean的类型
1.使用类构造器实例化 [默认的类构造器] <bean id=“orderService" class="cn.itcast.OrderServiceBean"/ ...
- WCF全面解析学习(1)
SOA的基本概念和设计思想 SOA并不是仅仅采用Web服务的架构,Web服务只是一种实现SOA的理想技术手段.SOA依赖于开放的标准.SOA的一个目标是让不同的厂商开发的服务能够相互操作. SOA支持 ...
- GnuStep使用
gcc -o main main1.m -I/GNUstep/System/Library/Headers -fconstant-string-class=NSConstantString -L/GN ...
- CodeForces 455D 分块
题目链接:http://codeforces.com/problemset/problem/455/D 题意:给定一个长度为n的序列a[]. m次操作.共有两种操作 1 l r:将序列的a[l].a[ ...
- OSS层基础:平台区分
#define PLATFORM_WINDOWS 1 #define PLATFORM_MAC 2 #define PLATFORM_UNIX 3 #if defined(_WIN32) #defin ...
- Ado.Net事物处理
protected void Button2_Click(object sender, EventArgs e) { SqlConnection con = new SqlCo ...
- 【转】HashMap、TreeMap、Hashtable、HashSet和ConcurrentHashMap区别
转自:http://blog.csdn.net/paincupid/article/details/47746341 一.HashMap和TreeMap区别 1.HashMap是基于散列表实现的,时间 ...
- ACM: FZU 2112 Tickets - 欧拉回路 - 并查集
FZU 2112 Tickets Time Limit:3000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u P ...