news 2026/5/30 20:09:34

[Wf2016]Branch Assignment题解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[Wf2016]Branch Assignment题解

P6918 [ICPC 2016 WF] Branch Assignment

题目描述

创新消费品公司(ICPC)计划启动一个绝密项目。该项目由sss个子项目组成。将有b≥sb \ge sbs个 ICPC 的分支机构参与此项目,ICPC 希望将每个分支机构分配给一个子项目。换句话说,这些分支机构将形成sss个不相交的组,每个组负责一个子项目。

每个月底,每个分支机构将向其组内的每个其他分支机构发送一条消息(每个分支机构接收不同的消息)。ICPC 有一个特定的通信协议。每个分支机构iii有一个只有该分支机构和 ICPC 总部知道的密钥kik_iki。假设分支机构iii想要向分支机构jjj发送消息。分支机构iii用其密钥kik_iki加密消息。一个可信的信使从该分支机构取走消息并将其交付给 ICPC 总部。总部用密钥kik_iki解密消息,并用密钥kjk_jkj重新加密。然后信使将这个新加密的消息交付给分支机构jjj,分支机构jjj用其自己的密钥kjk_jkj解密。出于安全原因,信使一次只能携带一条消息。

给定一个道路网络以及分支机构和总部在此网络中的位置,你的任务是确定信使在所有可能的分支机构到子项目的分配中,传递所有月底消息所需的最小总距离。

输入格式

输入的第一行包含四个整数nnnbbbsssrrr,其中nnn(2≤n≤5 0002 \le n \le 5\, 0002n5000) 是交叉路口的数量,bbb(1≤b≤n−11 \le b \le n-11bn1) 是分支机构的数量,sss(1≤s≤b1 \le s \le b1sb) 是子项目的数量,rrr(1≤r≤50 0001 \le r \le 50\, 0001r50000) 是道路的数量。交叉路口编号从111nnn。分支机构位于交叉路口111bbb,总部位于交叉路口b+1b + 1b+1。接下来的rrr行中的每一行包含三个整数uuuvvvℓ\ell,表示从交叉路口uuu到不同交叉路口vvv(1≤u,v≤n1 \leq u,v \leq n1u,vn) 的一条单向道路,长度为ℓ\ell(0≤ℓ≤10 0000 \leq \ell \leq 10\, 000010000)。没有有序对(u,v)(u,v)(u,v)会出现多次,并且从任何交叉路口都可以到达每个其他交叉路口。

输出格式

输出信使需要行驶的最小总距离。

输入输出样例 #1

输入 #1

5 4 2 10 5 2 1 2 5 1 3 5 5 4 5 0 1 5 1 2 3 1 3 2 5 2 4 5 2 1 1 3 4 2

输出 #1

13

输入输出样例 #2

输入 #2

5 4 2 10 5 2 1 2 5 1 3 5 5 4 5 10 1 5 1 2 3 1 3 2 5 2 4 5 2 1 1 3 4 2

输出 #2

24

说明/提示

时间限制:2000 毫秒,内存限制:1048576 kB。

国际大学生程序设计竞赛(ACM-ICPC)世界总决赛 2016。

题面翻译由 ChatGPT-4o 提供。

思路

动态规划
决策单调性
杂项
wqs二分

代码见下

#include<bits/stdc++.h>usingnamespacestd;longlongn,b,s,r,a[5005],aa[5005],uu,vv,ee,f[5005],df[100005];structone{longlongu,e;};vector<one>v[5005];vector<one>vx[5005];booloperator<(one a1,one b1){returna1.e>b1.e;}priority_queue<one>q;voidabc(longlongl,longlongr,longlongx,longlongy){if(l>=r+1){return;}if(r-l+1<=5||y-x+1<=5){for(inti=l;i<=r;i++){df[i]=1e18+7;for(intj=x;j<=min(i-1ll,y);j++){df[i]=min(df[i],f[j]+(a[i]-a[j])*(i-j-1));}}return;}longlongmid=(l+r)/2,p;df[mid]=1e18+7;for(inti=x;i<=min(mid,y);i++){if(f[i]+(a[mid]-a[i])*(mid-i-1)<=df[mid]-1){df[mid]=f[i]+(a[mid]-a[i])*(mid-i-1);p=i;}}abc(l,mid-1,x,p);abc(mid+1,r,p,y);return;}intmain(){cin>>n>>b>>s>>r;for(inti=1;i<=r;i++){cin>>uu>>vv>>ee;v[uu].push_back({vv,ee});vx[vv].push_back({uu,ee});}memset(a,62,sizeof(a));q.push({b+1,0});a[b+1]=0;while(q.size()!=0){longlonga1=q.top().u;//cout<<a1<<endl;q.pop();for(inti=0;i<v[a1].size();i++){one tt=v[a1][i];if(a[tt.u]>=a[a1]+tt.e+1){a[tt.u]=a[a1]+tt.e;q.push({tt.u,a[tt.u]});}}}memset(aa,62,sizeof(aa));q.push({b+1,0});aa[b+1]=0;while(q.size()!=0){longlonga1=q.top().u;//cout<<a1<<endl;q.pop();for(inti=0;i<vx[a1].size();i++){one tt=vx[a1][i];if(aa[tt.u]>=aa[a1]+tt.e+1){aa[tt.u]=aa[a1]+tt.e;q.push({tt.u,aa[tt.u]});}}}for(inti=1;i<=b;i++){a[i]+=aa[i];}//cout<<f[b][s]<<endl;sort(a+1,a+b+1);a[0]=0;for(inti=1;i<=b;i++){a[i]=a[i-1]+a[i];//cout<<i<<" "<<a[i]<<endl;}memset(f,62,sizeof(f));f[0]=0;for(intj=1;j<=s;j++){abc(1,b,0,b);for(inti=0;i<=b;i++){f[i]=df[i];}}cout<<f[b]<<endl;return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/29 17:07:36

[SDOI2016] 征途题解

P4072 [SDOI2016] 征途 题目描述 Pine 开始了从 SSS 地到 TTT 地的征途。 从 SSS 地到 TTT 地的路可以划分成 nnn 段&#xff0c;相邻两段路的分界点设有休息站。 Pine 计划用 mmm 天到达 TTT 地。除第 mmm 天外&#xff0c;每一天晚上 Pine 都必须在休息站过夜。所以&…

作者头像 李华
网站建设 2026/5/29 15:11:51

你的测试团队为何倦怠?重塑动机的心理学家方案

当代码遇见人心 在软件测试领域&#xff0c;我们常聚焦于缺陷追踪、用例设计或自动化脚本&#xff0c;却鲜少深入探讨测试活动背后的核心驱动力——人的动机。根据自我决定理论&#xff0c;人类行为受自主性、能力感与归属感三大心理需求影响。对测试工程师而言&#xff0c;动…

作者头像 李华
网站建设 2026/5/29 5:24:36

测试变革的推动:从执行者到价值创造者的演进

在数字化转型加速的今天&#xff0c;软件已渗透至各行各业&#xff0c;从金融交易到医疗健康&#xff0c;从智能家居到自动驾驶&#xff0c;软件的可靠性与安全性直接关系到用户体验乃至生命财产安全。作为软件质量的守护者&#xff0c;测试从业者正面临前所未有的挑战与机遇。…

作者头像 李华
网站建设 2026/5/23 18:24:55

SQL必会必知整理-12-使用子查询

12.1 子查询任何SQL语句都是查询。但此术语一般指SELECT语句。SQL还允许创建子查询&#xff08;subquery&#xff09;&#xff0c;即嵌套在其他查询中的查询。12.2 利用子查询进行过滤SELECT cust_id FROM orders WHERE order_num IN (SELECT order_numFROM orderitemsWHERE pr…

作者头像 李华
网站建设 2026/5/25 16:42:27

SSE换环境导致502问题

华为云 必须加固定请求头 headers.add("Content-Type", "text/event-stream");headers.add("Transfer-Encoding", "chunked");阿里云 // 阿里云不可以加 Transfer-Encoding&#xff0c;不然阿里云原生网关报错 502 // 可能原因 阿里云…

作者头像 李华
网站建设 2026/5/28 2:42:40

同花顺短线大赚副图 源码分享

{}IF(PERIODNAME<>"日线") { 统计:"该指标只在日线周期下有效。"; RETURN; } r:((ZDMR[-1]BDMR[-1])-(ZDMC[-1]BDMC[-1]))/SHGZG*100; 大单净量:r; D3:EMA(EMA(r,30),3)*30,color00ffff; D5:EMA(EMA(D3,5),3),colorff00cc; D10:EMA(EMA(D3,10),3),co…

作者头像 李华