正解:点分治

解题报告:

传送门$QwQ$

昂先不考虑关于那个长度的限制考虑怎么做?

就开个桶,记录所有边的取值,每次加入边的时候查下是否可行就成$QwQ$

然后现在考虑加入这个长度的限制?就考虑把这个桶,本来是个$bool$数组记录可行嘛,现在就改成$int$数组记录最小长度

然后就做完辣,,,?$QwQ$

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define il inline
  4. #define int long long
  5. #define gc getchar()
  6. #define t(i) edge[i].to
  7. #define w(i) edge[i].wei
  8. #define ri register int
  9. #define rb register bool
  10. #define rc register char
  11. #define rp(i,x,y) for(ri i=x;i<=y;++i)
  12. #define my(i,x,y) for(ri i=x;i>=y;--i)
  13. #define e(i,x) for(ri i=head[x];i;i=edge[i].nxt)
  14.  
  15. const int N=+,M=+,inf=1e9;
  16. int n,K,head[N],ed_cnt,mxsz[N],sum,sz[N],rt,as,cnt,dis1[N],dis2[N],stp[M];
  17. bool vis[N];
  18. struct ed{int to,nxt,wei;}edge[N<<];
  19.  
  20. il int read()
  21. {
  22. rc ch=gc;ri x=;rb y=;
  23. while(ch!='-' && (ch>'' || ch<''))ch=gc;
  24. if(ch=='-')ch=gc,y=;
  25. while(ch>='' && ch<='')x=(x<<)+(x<<)+(ch^''),ch=gc;
  26. return y?x:-x;
  27. }
  28. il void ad(ri x,ri y,ri z){edge[++ed_cnt]=(ed){x,head[y],z};head[y]=ed_cnt;}
  29. void dfs(ri x,ri fa)
  30. {
  31. sz[x]=;mxsz[x]=;
  32. e(i,x)if(t(i)^fa && !vis[t(i)])dfs(t(i),x),sz[x]+=sz[t(i)],mxsz[x]=max(mxsz[x],sz[t(i)]);
  33. mxsz[x]=max(mxsz[x],sum-sz[x]);if(mxsz[x]<mxsz[rt])rt=x;
  34. }
  35. void dfs2(ri x,ri fa,ri d1,ri d2)
  36. {if(d1>K)return;dis1[++cnt]=d1,dis2[cnt]=d2;e(i,x)if(!vis[t(i)] && t(i)^fa)dfs2(t(i),x,d1+w(i),d2+);}
  37. il void cal(ri x)
  38. {
  39. stp[]=;cnt=;
  40. e(i,x)
  41. {
  42. if(!vis[t(i)])
  43. {
  44. ri tmp=cnt;dfs2(t(i),x,w(i),);
  45. rp(j,tmp+,cnt){as=min(as,dis2[j]+stp[K-dis1[j]]);/*printf("x=%d to=%d dis1j=%d dis2j=%d stp=%d len=%d\n",x,t(i),dis1[j],dis2[j],stp[K-dis1[j]],K-dis1[j]);*/}
  46. rp(j,tmp+,cnt)stp[dis1[j]]=min(stp[dis1[j]],dis2[j]);
  47. }
  48. }
  49. //printf(" x=%d as=%d\n",x,as);
  50. rp(i,,cnt)stp[dis1[i]]=stp[K+];
  51. }
  52. void solv(ri x){/*printf("rt=%d\n",x);*/vis[x]=;cal(x);e(i,x)if(!vis[t(i)])sum=sz[x],rt=,dfs(t(i),x),solv(rt);}
  53.  
  54. signed main()
  55. {
  56. //freopen("4149.in","r",stdin);freopen("4149.out","w",stdout);
  57. n=read();K=read();rp(i,,n-){ri x=read()+,y=read()+,z=read();ad(x,y,z);ad(y,x,z);}
  58. mxsz[rt]=sum=n;dfs(,);memset(stp,,sizeof(stp));as=stp[];solv(rt);printf("%lld\n",as==stp[K+]?-:as);
  59. return ;
  60. }

洛谷$P4149\ [IOI2011]\ Race$ 点分治的更多相关文章

  1. [洛谷P4149][IOI2011]Race

    题目大意:给一棵树,每条边有边权.求一条简单路径,权值和等于$K$,且边的数量最小. 题解:点分治,考虑到这是最小值,不满足可减性,于是点分中的更新答案的地方计算重复的部分要做更改,就用一个数组记录前 ...

  2. 模板—点分治B(合并子树)(洛谷P4149 [IOI2011]Race)

    洛谷P4149 [IOI2011]Race 点分治作用(目前只知道这个): 求一棵树上满足条件的节点二元组(u,v)个数,比较典型的是求dis(u,v)(dis表示距离)满足条件的(u,v)个数. 算 ...

  3. 洛谷 P4149 [IOI2011]Race-树分治(点分治,不容斥版)+读入挂-树上求一条路径,权值和等于 K,且边的数量最小

    P4149 [IOI2011]Race 题目描述 给一棵树,每条边有权.求一条简单路径,权值和等于 KK,且边的数量最小. 输入格式 第一行包含两个整数 n, Kn,K. 接下来 n - 1n−1 行 ...

  4. 洛谷 4149 [IOI2011]Race——点分治

    题目:https://www.luogu.org/problemnew/show/P4149 第一道点分治! 点分治大约是每次找重心,以重心为根做一遍树形dp:然后对于该根的每个孩子,递归下去.递归之 ...

  5. 洛谷P4149 [IOI2011]Race(点分治)

    题目描述 给一棵树,每条边有权.求一条简单路径,权值和等于 KK ,且边的数量最小. 输入输出格式 输入格式:   第一行:两个整数 n,kn,k . 第二至 nn 行:每行三个整数,表示一条无向边的 ...

  6. P4149 [IOI2011]Race

    对于这道题,明显是点分治,权值等于k,可以用桶统计树上路径(但注意要清空); 对于每颗子树,先与之前的子树拼k,再更新桶,维护t["len"]最小边数; #include < ...

  7. P4149 [IOI2011]Race 点分治

    思路: 点分治 提交:5次 题解: 刚开始用排序+双指针写的,但是调了一晚上,总是有两个点过不了,第二天发现原因是排序时的\(cmp\)函数写错了:如果对于路径长度相同的,我们从小往大按边数排序,当双 ...

  8. LUOGU P4149 [IOI2011]Race

    题目描述 给一棵树,每条边有权.求一条简单路径,权值和等于 KKK ,且边的数量最小. 输入输出格式 输入格式: 第一行:两个整数 n,kn,kn,k . 第二至 nnn 行:每行三个整数,表示一条无 ...

  9. 洛谷 P4149 [ IOI 2011 ] Race —— 点分治

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

随机推荐

  1. Python基础:常用函数

    1:enumerate enumerate(sequence, start=0) 该函数返回一个enumerate对象(一个迭代器).其中的sequence参数可以是序列.迭代器或者支持迭代的其他对象 ...

  2. PAN-OS 6.1 Open Source Software (OSS) Listing

    https://www.paloaltonetworks.com/documentation/oss-listings/oss-listings/pan-os-oss-listings/pan-os- ...

  3. Open Source GIS and Freeware GIS Applications

    Open Source GIS and Freeware GIS Applications   An open source application by definition is software ...

  4. APICloud ajax请求api数据问题

    云编译开启全局加密的情况下,请务必使用api.ajax,避免使用JQ等框架的ajax,否则将引起请求失败.官网API说明链接 还要就是要注意用$.ajax请求数据时会出现的同源策略问题.

  5. iptables 连线追踪(Connection tracking)

    「连線追蹤」:提供可用於判断包相关性的额外资讯.举例来說,一次FTP session同时需要两条分离的连線,控制与资料传输各一:用於追蹤FTP连線的扩充模组,运用对於FTP恊定的认知,从控制连線上流动 ...

  6. laravel多表登录出现路由调用错误

    public function auth() { // Authentication Routes... $this->get('login', 'Auth\LoginController@sh ...

  7. 解决TortoiseSVN中out of date问题的一个方法

    http://blog.csdn.net/freefalcon/article/details/645058 从去年开始,公司的代码管理从CVS转向了subvsersion,后者确实是前者的一个飞跃, ...

  8. [转][ASP.NET Core 3框架揭秘] 跨平台开发体验: Windows [中篇]

    我们在<上篇>利用dotnet new命令创建了一个简单的控制台程序,接下来我们将它改造成一个ASP.NET Core应用.一个ASP.NET Core应用构建在ASP.NET Core框 ...

  9. Python 3.7.0 For Mac版软件安装教程附下载地址

    https://www.jianshu.com/p/f02d6f01eba7

  10. JS拉平数组

    JS拉平数组 有时候会遇到一个数组里边有多个数组的情况(多维数组),然后你想把它拉平使其成为一个一维数组,其实最简单的一个方法就是ES6数组方法Array.prototype.flat.使用方法如下: ...