【BZOJ 2599】【IOI 2011】Race 点分治

时间:2022-09-26 00:08:41

裸的点分治,然而我因为循环赋值$s$时把$i <= k$写成$i <= n$了,WA了好长时间

#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 200100
#define inf 2147483647
#define max(a,b) (a)>(b)?(a):(b)
#define min(a,b) (a)<(b)?(a):(b)
#define read(x) x=getint()
using namespace std;
inline int getint() {
int fh = 1, k = 0; char c = getchar();
for(; c < '0' || c > '9'; c = getchar())
if (c == '-') fh = -1;
for(; c >= '0' && c <= '9'; c = getchar())
k = k * 10 + c - '0';
return k * fh;
}
struct node {
int nxt, to, w;
} E[N << 1];
bool vis[N];
int cnt = 0, s[1000100], rtm = inf, root, sz[N], dist[N], deep[N], n, k, ans, point[N];
inline void ins(int x, int y, int z) {++cnt; E[cnt].nxt = point[x]; E[cnt].to = y; E[cnt].w = z; point[x] = cnt;}
inline void fdrt(int x, int fa, int sh) {
sz[x] = 1;
int ma = 0;
for(int tmp = point[x]; tmp; tmp = E[tmp].nxt) {
int v = E[tmp].to;
if (vis[v] || v == fa)
continue;
fdrt(v, x, sh);
sz[x] += sz[v];
ma = max(ma, sz[v]);
}
ma = max(ma, sh - ma);
if (ma < rtm) {
rtm = ma;
root = x;
}
}
inline void work(int x, int fa) {
if (dist[x] <= k)
ans = min(ans, deep[x] + s[k - dist[x]]);
for(int tmp = point[x]; tmp; tmp = E[tmp].nxt) {
int v = E[tmp].to;
if (vis[v] || v == fa)
continue;
dist[v] = dist[x] + E[tmp].w;
deep[v] = deep[x] + 1;
work(v, x);
}
}
inline void sfill(int x, int fa) {
if (dist[x] < k)
s[dist[x]] = min(s[dist[x]], deep[x]);
for(int tmp = point[x]; tmp; tmp = E[tmp].nxt) {
int v = E[tmp].to;
if (vis[v] || v == fa)
continue;
sfill(v, x);
}
}
inline void emp(int x, int fa) {
if (dist[x] < k)
s[dist[x]] = n + 1;
for(int tmp = point[x]; tmp; tmp = E[tmp].nxt) {
int v = E[tmp].to;
if (vis[v] || v == fa)
continue;
emp(v, x);
}
}
inline void dfs(int x, int sh) {
vis[x] = 1;
s[0] = 0; //不能落下这个点!!因为后面会更新不到,而且有可能会更改s[0]的值
for(int tmp = point[x]; tmp; tmp = E[tmp].nxt) {
int v = E[tmp].to;
if (vis[v])
continue;
dist[v] = E[tmp].w;
deep[v] = 1;
work(v, x);
sfill(v, x);
}
for(int tmp = point[x]; tmp; tmp = E[tmp].nxt) {
int v = E[tmp].to;
if (vis[v])
continue;
emp(v, x);
}
for(int tmp = point[x]; tmp; tmp = E[tmp].nxt) {
int v = E[tmp].to;
if (vis[v])
continue;
int ss = sz[v] < sz[x] ? sz[v]: sh - sz[x];
rtm = inf;
fdrt(v, x, ss);
dfs(root, ss);
}
}
int main() {
read(n); read(k);
int a,b,c;
for(int i = 1; i < n; ++i) {
read(a); read(b); read(c); ++a; ++b;
ins(a, b, c);
ins(b, a, c);
}
ans = n;
memset(vis, 0, sizeof(vis));
fdrt(1, -1, n);
for(int i = 0; i <= k; ++i)
s[i] = n + 1;
dfs(1, n);
printf("%d\n", ans == n ? -1 : ans);
return 0;
}

然后就可以了

【BZOJ 2599】【IOI 2011】Race 点分治的更多相关文章

  1. 洛谷 P4149 &lbrack; IOI 2011 &rsqb; Race —— 点分治

    题目:https://www.luogu.org/problemnew/show/P4149 仍然是点分治: 不过因为是取 min ,所以不能用容斥,那么子树之间就必须分开算,记录桶时注意这个: 每次 ...

  2. &lbrack;IOI 2011&rsqb;Race

    Description 给一棵树,每条边有非负权.求一条简单路径,权值和等于K,且边的数量最小.N <= 200000, 1 <= K <= 1000000 Input 第一行 两个 ...

  3. 【IOI 2011】Race

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=2599 [算法] 点分治 [代码] #include<bits/stdc++.h ...

  4. &lbrack;BZOJ 2299&rsqb;&lbrack;HAOI 2011&rsqb;向量 题解(裴蜀定理)

    [BZOJ 2299][HAOI 2011]向量 Description 给你一对数a,b,你可以任意使用(a,b), (a,-b), (-a,b), (-a,-b), (b,a), (b,-a), ...

  5. Luogu 3810 &amp&semi; BZOJ 3262 陌上花开&sol;三维偏序 &vert; CDQ分治

    Luogu 3810 & BZOJ 3263 陌上花开/三维偏序 | CDQ分治 题面 \(n\)个元素,每个元素有三个值:\(a_i\), \(b_i\) 和 \(c_i\).定义一个元素的 ...

  6. &lbrack;BZOJ 2301&rsqb; &lbrack;HAOI 2011&rsqb; Problem b &lpar;莫比乌斯反演&rpar;&lpar;有证明&rpar;

    [BZOJ 2301] [HAOI 2011] Problem b (莫比乌斯反演)(有证明) 题面 T组询问,每次给出a,b,c,d,k,求\(\sum _{i=a}^b\sum _{j=c}^d[ ...

  7. BZOJ 2599&colon; &lbrack;IOI2011&rsqb;Race&lpar; 点分治 &rpar;

    数据范围是N:20w, K100w. 点分治, 我们只需考虑经过当前树根的方案. K最大只有100w, 直接开个数组CNT[x]表示与当前树根距离为x的最少边数, 然后就可以对根的子树依次dfs并更新 ...

  8. bzoj 2599 &lbrack;IOI2011&rsqb;Race (点分治)

    [题意] 问树中长为k的路径中包含边数最少的路径所包含的边数. [思路] 统计经过根的路径.假设当前枚举到根的第S个子树,若x属于S子树,则有: ans<-dep[x]+min{ dep[y] ...

  9. BZOJ 2599 Race&lpar;树分治&rpar;

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2599 题意:给一棵树,每条边有权.求一条路径,权值和等于K,且边的数量最小. 题意:每次 ...

随机推荐

  1. MAC上显示隐藏文件夹

    第一步:打开「终端」应用程序. 第二步:输入如下命令: defaults write com.apple.finder AppleShowAllFiles -boolean true ; killal ...

  2. 一年成为emacs高手

    http://blog.csdn.net/redguardtoo/article/details/7222501

  3. UIButton&lpar;改变Title和image位置&rpar;

    UIButton *btn = [[UIButton alloc] init]; [btn setFrame:frame]; [btn setTitleColor:titleColor forStat ...

  4. Jersey the RESTful Web Services in Java

    Jersey 是一个JAX-RS的实现, JAX-RS即Java API for RESTful Web Services, 支持按照表述性状态转移(REST)架构风格创建Web服务. REST 中最 ...

  5. javascript笔记—— 构造函数

    出处:http://www.cnblogs.com/RicCC/archive/2008/02/15/JavaScript-Object-Model-Execution-Model.html 数据类型 ...

  6. 制作静态库文件(&period;a文件)

    制作静态库文件(.a文件) 1.创建静态库工程: 在Xcode中new一个新的project,选择IOS下面的Framework&Library,下面有一个Cocoa Touch Static ...

  7. 自定义UITableViewCell时&comma; 使用autoLayout&comma; 无法很好的做到屏幕适配

    解决方法: 重写cell的setFrame方法即可 - (void)setFrame:(CGRect)frame { frame.size.width = self.window.frame.size ...

  8. JAVA&lowbar;SE基础——8&period;基本数据类型

    基本数据类型有:整数类型.浮点类型.字符类型.布尔类型 整数类型 整数类型用来存储整数数值,即没有小数部分的数值.与C.C++语言相同,整数在Java语言中有3种表示形式:十进制.八进制和十六进制. ...

  9. iview render Datepicker 起止时间限制

    { title: '开始时间', key: 'planDateFrom', minWidth: 120, sortable: true, align: 'center', render: (h, pa ...

  10. asynicio模块以及爬虫应用asynicio模块&lpar;高性能爬虫&rpar;

    一.背景知识 爬虫的本质就是一个socket客户端与服务端的通信过程,如果我们有多个url待爬取,只用一个线程且采用串行的方式执行,那只能等待爬取一个结束后才能继续下一个,效率会非常低. 需要强调的是 ...