旅行商(sale)

题目描述

camp国有n座城市,由1,2,…,n编号。城市由n–1条双向道路相连。任意两个城市之间存在唯一的道路连通。有m个旅行商,第i个旅行商会从城市ai旅行到城市bi,贩卖ci件商品。已知第i个城市的居民最多购买wi件商品,bobo想知道旅行商们能够卖出商品数量的最大值。

输入

输入文件sale.in。

第一行,包含2个整数n和m。

第二行,包含n个整数w1,w2,…,wn。

接下来n–1行中的第i行包含2个整数ui,vi代表城市ui和vi之间有一条道路。

最后的m行中的第i行包含3个整数ai,bi,ci。

输出

输出文件sale.out。

1个整数,代表卖出商品数量的最大值。

样例输入

  1. 4 2
  2. 0 1 2 2
  3. 1 4
  4. 2 4
  5. 3 4
  6. 1 2 2
  7. 1 3 3

样例输出

  1. 5

提示

【数据范围和约定】

数据点

n,m的范围

其他

1

≤500

1≤ui,vi,ai,bi≤n

0≤wi,ci≤105

2

3

4

≤5,000

5

6

7

≤2×104

8

9

10

solution

树剖,转化为区间问题

先暴力建图

每个旅行商向他要去的所有城市连边,发现边数n^2

考虑用线段树优化建图,城市开成线段树,旅行商向节点连边

然后就可以啦

好裸的题

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<algorithm>
  6. #include<cmath>
  7. #include<vector>
  8. #include<queue>
  9. #define maxn 20005
  10. #define N 400005
  11. #define inf 1e9
  12. using namespace std;
  13. int n,m,w[maxn],dfn[maxn],sc,son[maxn],fa[maxn],top[maxn],size[maxn];
  14. int deep[maxn],t1,t2,t3,tot=1,a,b,c,dy[maxn],li,ri,cnt,S,T,ans;
  15. int head[N],cur[N],flag[N],d[N];
  16. queue<int>q;
  17. vector<int>G[maxn];
  18. struct node{
  19. int v,nex,cap;
  20. }e[N*20];
  21. struct no{
  22. int l,r,x;
  23. }tree[maxn*4];
  24. void lj(int t1,int t2,int t3){
  25. e[++tot].v=t2;e[tot].cap=t3;e[tot].nex=head[t1];head[t1]=tot;
  26. e[++tot].v=t1;e[tot].cap=0;e[tot].nex=head[t2];head[t2]=tot;
  27. }
  28. void dfs1(int k,int fath){
  29. fa[k]=fath;deep[k]=deep[fath]+1;
  30. int sz=0,gp=-1;
  31. for(int i=0;i<G[k].size();i++){
  32. int v=G[k][i];
  33. if(v!=fath){
  34. dfs1(v,k);
  35. sz+=size[v];
  36. if(gp==-1)gp=v;
  37. else if(size[v]>size[gp])gp=v;
  38. }
  39. }
  40. size[k]=sz+1;son[k]=gp;
  41. }
  42. void dfs2(int k){
  43. dfn[k]=++sc;dy[sc]=k;
  44. if(son[k]!=-1)top[son[k]]=top[k],dfs2(son[k]);
  45. for(int i=0;i<G[k].size();i++){
  46. int v=G[k][i];
  47. if(v!=fa[k]&&v!=son[k]){
  48. top[v]=v;dfs2(v);
  49. }
  50. }
  51. }
  52. void wh(int k){
  53. tree[k].x=tree[k*2].x+tree[k*2+1].x;
  54. }
  55. void build(int k,int L,int R){
  56. tree[k].l=L,tree[k].r=R;
  57. if(L==R){
  58. tree[k].x=w[dy[L]];lj(k,T,w[dy[L]]);
  59. cnt=max(cnt,k);
  60. return;
  61. }
  62. int mid=L+R>>1;
  63. build(k*2,L,mid);build(k*2+1,mid+1,R);
  64. lj(k,k*2,tree[k*2].x);lj(k,k*2+1,tree[k*2+1].x);
  65. wh(k);
  66. }
  67. void fsy(int k,int id){
  68. if(tree[k].l>=li&&tree[k].r<=ri){
  69. lj(id,k,inf);return;
  70. }
  71. int mid=tree[k].l+tree[k].r>>1;
  72. if(li<=mid)fsy(k*2,id);
  73. if(ri>mid)fsy(k*2+1,id);
  74. }
  75. bool BFS(){
  76. for(int i=1;i<=T;i++)d[i]=inf;
  77. d[S]=0;q.push(S);
  78. while(!q.empty()){
  79. int x=q.front();q.pop();
  80. cur[x]=head[x];
  81. for(int i=head[x];i;i=e[i].nex){
  82. if(d[e[i].v]>d[x]+1&&e[i].cap>0){
  83. d[e[i].v]=d[x]+1;
  84. if(!flag[e[i].v]){
  85. flag[e[i].v]=1;q.push(e[i].v);
  86. }
  87. }
  88. }
  89. flag[x]=0;
  90. }
  91. return d[T]!=inf;
  92. }
  93. int lian(int k,int a){
  94. if(k==T||!a)return a;
  95. int f,flow=0;
  96. for(int &i=cur[k];i;i=e[i].nex){
  97. if(d[e[i].v]==d[k]+1&&(f=lian(e[i].v,min(e[i].cap,a)))>0){
  98. e[i].cap-=f;e[i^1].cap+=f;
  99. a-=f;flow+=f;
  100. if(!a)break;
  101. }
  102. }
  103. return flow;
  104. }
  105. int main()
  106. {
  107. cin>>n>>m;S=400001,T=S+1;
  108. for(int i=1;i<=n;i++)scanf("%d",&w[i]);
  109. for(int i=1;i<n;i++){
  110. scanf("%d%d",&t1,&t2);
  111. G[t1].push_back(t2);G[t2].push_back(t1);
  112. }
  113. dfs1(1,0);top[1]=1;dfs2(1);
  114. build(1,1,n);
  115. for(int i=1;i<=m;i++){
  116. scanf("%d%d%d",&a,&b,&c);
  117. int t1=top[a],t2=top[b];
  118. while(t1!=t2){
  119. if(deep[t1]<deep[t2])swap(t1,t2),swap(a,b);
  120. li=dfn[t1],ri=dfn[a];
  121. fsy(1,cnt+i);
  122. a=fa[t1];t1=top[a];
  123. }
  124. if(deep[a]<deep[b])swap(a,b);
  125. li=dfn[b],ri=dfn[a];
  126. fsy(1,cnt+i);
  127. lj(S,cnt+i,c);
  128. }
  129. while(BFS())ans+=lian(S,inf);
  130. cout<<ans<<endl;
  131. return 0;
  132. }

旅行商(sale)的更多相关文章

  1. 【C#代码实战】群蚁算法理论与实践全攻略——旅行商等路径优化问题的新方法

    若干年前读研的时候,学院有一个教授,专门做群蚁算法的,很厉害,偶尔了解了一点点.感觉也是生物智能的一个体现,和遗传算法.神经网络有异曲同工之妙.只不过当时没有实际需求学习,所以没去研究.最近有一个这样 ...

  2. 洛谷P1782 旅行商的背包[多重背包]

    题目描述 小S坚信任何问题都可以在多项式时间内解决,于是他准备亲自去当一回旅行商.在出发之前,他购进了一些物品.这些物品共有n种,第i种体积为Vi,价值为Wi,共有Di件.他的背包体积是C.怎样装才能 ...

  3. 2016全国研究生数学建模A题多无人机协同任务规划——基于分布式协同多旅行商MTSP遗传算法

    MTSP问题是指:有Ⅳ个城市,要求旅行商到达每个城市各一次,且仅一次,并[旦 1到起点,且要求旅行路线最短.而多旅行商问题M个旅行商从同一个城市(或多个城市)出发.分羽走一条旅路线,且总路程缀短.有关 ...

  4. [vijos P1014] 旅行商简化版

    昨天早上上课讲旅行商问题,有点难,这周抽空把3^n的算法码码看.不过这个简化版已经够折腾人了. 其一不看解析不知道这是双进程动态规划,不过我看的解析停留在f[i,j]表示第一个人走到i.第二个人走到j ...

  5. vijosP1014 旅行商简化版

    vijosP1014 旅行商简化版 链接:https://vijos.org/p/1014 [思路] 双线DP. 设ab,ab同时走.用d[i][j]表示ab所处结点i.j,且定义i>j,则有转 ...

  6. 洛谷【P1523】旅行商的背包(算法导论 15-1) 题解

    P1523 旅行商简化版 题目背景 欧几里德旅行商\((Euclidean Traveling Salesman)\)问题也就是货郎担问题一直是困扰全世界数学家.计算机学家的著名问题.现有的算法都没有 ...

  7. Bzoj3352 [ioi2009]旅行商

    Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 89  Solved: 36 Description 旅行商认定如何优化旅行路线是一个非常棘手的计算问题 ...

  8. hdu 4281 Judges' response(多旅行商&DP)

    Judges' response Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  9. 洛谷P1523 旅行商简化版(DP)

    题目: P1523 旅行商简化版 解析 可以看做是两个人同时从西往东走,经过不一样的点,走到最东头的方案数 设\(f[i][j]\)表示一个人走到i,一个人走到j的最短距离(\(i<j\)) 第 ...

随机推荐

  1. 交叉验证(Cross Validation)方法思想简介

      以下简称交叉验证(Cross Validation)为CV.CV是用来验证分类器的性能一种统计分析方法,基本思想是把在某种意义下将原始数据(dataset)进行分组,一部分做为训练集(train ...

  2. DeepLearning tutorial(3)MLP多层感知机原理简介+代码详解

    本文介绍多层感知机算法,特别是详细解读其代码实现,基于python theano,代码来自:Multilayer Perceptron,如果你想详细了解多层感知机算法,可以参考:UFLDL教程,或者参 ...

  3. 使用vue-cli创建项目

    使用Vue UI创建.管理项目 1.全局安装vue-cli 3.0 npm install -g @vue/cli 2.启动vue ui 创建项目: vue ui

  4. SOA架构,dubbo,Zookeeper

    1. 分析 由于项目是基于soa的架构,表现层和服务层是不同的工程.所以要实现查询需要两个系统之间进行通信. 如何实现远程通信? 1.Webservice:效率不高基于soap协议.项目中不推荐使用. ...

  5. 1305: [CQOI2009]dance跳舞

    Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 4169  Solved: 1804[Submit][Status][Discuss] Descripti ...

  6. 同时启动多个tomcat的配置信息

    同时启动多个tomcat的配置信息 下面把该配置文件中各端口的含义说明下. <Server port="8005" shutdown="SHUTDOWN" ...

  7. 常见react面试题汇总

    已经开源 地址:https://github.com/nanhupatar...关注我们团队: React 中 keys 的作用是什么? Keys 是 React 用于追踪哪些列表中元素被修改.被添加 ...

  8. Memory loss【记忆缺失】

    Memory Loss Losing your ability to think and remember is pretty scary. We know the risk of dementia ...

  9. 笔记-python-tutorial-8.errors and exceptions

    笔记-python-tutorial-8.errors and exceptions 1.      errors and exceptions 1.1.    syntax errors >& ...

  10. C#串口扫描枪的简单实现

    原文:C#串口扫描枪的简单实现 串口扫描枪的简单实现 基于串口通讯的扫描枪的实现,主要借助SerialPort类,表示串行端口资源.实现很简单: 工具:usb转RS232转接头/个,扫描枪/套, 扫描 ...