【NOI2008】 奥运物流

2023-11-07 16:30
文章标签 物流 奥运 noi2008

本文主要是介绍【NOI2008】 奥运物流,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述
奥运物流
【问题描述】
2008 北京奥运会即将开幕,
举国上下都在为这一盛事做好准备。
为了高效率、
成功地举办奥运会,对物流系统进行规划是必不可少的。
物流系统由若干物流基站组成,以 1...N 进行编号。每个物流基站 i 都有且
仅有一个后继基站 Si,而可以有多个前驱基站。基站 i 中需要继续运输的物资都
将被运往后继基站 Si,显然一个物流基站的后继基站不能是其本身。编号为 1 的
从任何物流基站都可将物资运往控制基站。
注意控制基
物流基站称为控制基站,
站也有后继基站,以便在需要时进行物资的流通。在物流系统中,高可靠性与低
成本是主要设计目。对于基站 i,我们定义其“可靠性” R (i ) 如下:
设物流基站 i 有 w 个前驱基站 P1, P2 ,Pw ,即这些基站以 i 为后继基站,则基站 i 的可靠性 R(i)满足下式:w
R(i ) = Ci + k ∑ R( Pj )j =1
其中 Ci 和 k 都是常实数且恒为正,且有 k 小于 1。
整个系统的可靠性与控制基站的可靠性正相关,
我们的目标是通过修改物流系统,即更改某些基站的后继基站,使得控制基站的可靠性 R(1)尽量大。但由于经费限制,最多只能修改 m 个基站的后继基站,并且,控制基站的后继基站不可被修改。因而我们所面临的问题就是,如何修改不超过 m 个基站的后继,使
得控制基站的可靠性 R(1)最大化。
【输入格式】
输入文件 trans.in 第一行包含两个整数与一个实数,N, m, k。其中 N 表示基
站数目,m 表示最多可修改的后继基站数目,k 分别为可靠性定义中的常数。
第二行包含 N 个整数,分别是 S1, S2...SN,即每一个基站的后继基站编号。
第三行包含 N 个正实数,分别是 C1, C2...CN,为可靠性定义中的常数。
【输出格式】
输出文件 trans.out 仅包含一个实数,为可得到的最大 R(1)。精确到小数点两
位。
【输入样例】
4 1 0.5
2313
10.0 10.0 10.0 10.0
【输出样例】
30.00
【样例说明】
原有物流系统如左图所示,4 个物流基站的可靠性依次为 22.8571,21.4286,
25.7143,10。
最优方案为将 2 号基站的后继基站改为 1 号,如右图所示。 此时 4 个基站
的可靠性依次为 30,25,15,10。
【数据规模和约定】
本题的数据,具有如下分布:
测试数据编号            N                              M
166
21212
360                           0
460                           1
560                          N-2
6~106060
对于所有的数据,满足 m ≤ N ≤ 60,Ci ≤ 106,0.3 ≤ k < 1,请使用双精度实
数,无需考虑由此带来的误差。

 

题解

 

解法1:贪心
  1 (*
  2     *Problem:    NOI2008 奥运物流
  3     *Author :    Chen Yang
  4     *Time   :    2012.5.20
  5     *State  :    70分
  6     *Memo    :    贪心
  7 *)
  8 program trans;
  9 type
 10   ty1=^ty2;
 11   ty2=record
 12      x:longint;
 13      next:ty1;
 14   end;
 15 var
 16   n,m,i:longint;
 17   k,ans:extended;
 18   father:array[0..100] of longint;
 19   c,r:array[0..100] of extended;
 20   get:array[0..100] of boolean;
 21   first:array[0..100] of ty1;
 22 //=====================
 23 procedure insert(x,y:longint);
 24 var
 25   p:ty1;
 26 begin
 27   new(p);
 28   p^.x:=y;
 29   p^.next:=first[x];
 30   first[x]:=p;
 31 end;
 32 //=====================
 33 procedure find(i:longint; kx:extended);
 34 var
 35   p:ty1;
 36   x:extended;
 37   son:longint;
 38 begin
 39   p:=first[i]; x:=0; son:=0;
 40   while p<>nil do
 41   begin
 42     if not get[p^.x] then
 43     begin
 44       find(p^.x,kx);
 45       x:=x+r[p^.x];
 46     end else son:=p^.x;
 47     p:=p^.next;
 48   end;
 49   if not get[i] then r[i]:=x*k+c[i] else ans:=ans+c[i]*kx+x*kx*k;
 50   if son>0 then find(son,kx*k);
 51 end;
 52 //=====================
 53 procedure work;
 54 var
 55   i,t:longint;
 56   kx:extended;
 57 begin
 58   fillchar(first,sizeof(first),0);
 59   fillchar(get,sizeof(get),false);
 60   for i:=2 to n do insert(father[i],i);
 61   ans:=0; t:=0;
 62   i:=1;
 63   while father[i]<>1 do
 64   begin
 65     inc(t);
 66     get[i]:=true;
 67     i:=father[i];
 68   end;
 69   get[i]:=true; inc(t);
 70   find(1,1);
 71   kx:=1;
 72   for i:=1 to t do kx:=kx*k;
 73   ans:=ans/(1-kx);
 74 end;
 75 //=====================
 76 procedure main;
 77 var
 78   i,t,k,j:longint;
 79 begin
 80   work; r[1]:=ans;
 81   if m=0 then writeln(ans:0:2) else
 82   if m=n-2 then
 83   begin
 84     for i:=2 to n do father[i]:=1;
 85     work;
 86     writeln(ans:0:2);
 87   end else
 88   begin
 89     for j:=1 to m do
 90     begin
 91       k:=0;
 92       for i:=2 to n do
 93       if father[i]<>1 then
 94       begin
 95         t:=father[i]; father[i]:=1;
 96         work;
 97         if r[1]<ans then begin r[1]:=ans; k:=i; end;
 98         father[i]:=t;
 99       end;
100       father[k]:=1;
101     end;
102     writeln(r[1]:0:2);
103   end;
104 end;
105 //=====================
106 begin
107   assign(input,'trans.in'); reset(input);
108   assign(output,'trans.out'); rewrite(output);
109   read(n,m,k);
110   for i:=1 to n do read(father[i]);
111   for i:=1 to n do read(c[i]);
112   main;
113   close(input); close(output);
114 end.

 

解法2:树形DP
 1 (*
 2     *Problem:    NOI2008 奥运物流
 3     *Author :    Chen Yang
 4     *Time   :    2012.5.20
 5     *State  :    AC
 6     *Memo    :    树形DP,多重背包
 7 *)
 8 program trans;
 9 uses math;
10 const maxn=65;
11 var
12   n,m,i,len:longint;
13   k,ans:extended;
14   fa:array[0..maxn] of longint;
15   c,kk,ff:array[0..maxn] of extended;
16   f,g:array[0..maxn,0..maxn,0..maxn] of extended;
17 //==================
18 procedure find(x,d:longint);
19 var
20   i,j,k,l:longint;
21 begin
22   for i:=2 to n do if fa[i]=x then find(i,d+1);
23   for k:=min(2,d) to d do
24   begin
25     for i:=0 to m do ff[i]:=0;
26     for i:=2 to n do if fa[i]=x then
27     for j:=m downto 0 do
28     for l:=j downto 0 do
29     if ff[j]<ff[l]+g[i,j-l,k] then ff[j]:=ff[l]+g[i,j-l,k];
30     for i:=0 to m do f[x,i,k]:=ff[i]+kk[k]*c[x];
31   end;
32   if d<>1 then
33   begin
34     for i:=0 to m do ff[i]:=0;
35     for i:=2 to n do if fa[i]=x then
36     for j:=m downto 0 do
37     for l:=j downto 0 do
38     if ff[j]<ff[l]+g[i,j-l,1] then ff[j]:=ff[l]+g[i,j-l,1];
39     for i:=1 to m do f[x,i,1]:=ff[i-1]+kk[1]*c[x];
40   end;
41   for j:=0 to m do
42   for k:=0 to d-1 do
43   if f[x,j,k+1]>f[x,j,1] then g[x,j,k]:=f[x,j,k+1] else g[x,j,k]:=f[x,j,1];
44 end;
45 //==================
46 procedure work(father:longint);
47 var
48   i,j,k:longint;
49   t:extended;
50 begin
51   fillchar(f,sizeof(f),0);
52   fillchar(g,sizeof(g),0);
53   for i:=2 to n do if fa[i]=1 then find(i,1);
54   for i:=0 to m do ff[i]:=0;
55   for i:=2 to n do if fa[i]=1 then
56   for j:=m downto 0 do
57   for k:=j downto 0 do
58   if ff[j]<ff[k]+f[i,j-k,1] then
59   ff[j]:=ff[k]+f[i,j-k,1];
60   t:=0;
61   for i:=0 to m-1 do
62   if t<ff[i] then t:=ff[i];
63   if (father=1)and(ff[m]>t) then t:=ff[m];
64   t:=(t+c[1])/(1-kk[len]);
65   if ans<t then ans:=t;
66 end;
67 //==================
68 procedure main;
69 var
70   i,t:longint;
71 begin
72   kk[0]:=1; for i:=1 to n do kk[i]:=kk[i-1]*k;
73   i:=fa[1]; len:=1;
74   while i<>1 do
75   begin
76     inc(len); t:=fa[i]; fa[i]:=1;
77     work(t);
78     fa[i]:=t; i:=t;
79   end;
80   writeln(ans:0:2);
81 end;
82 //==================
83 begin
84   assign(input,'trans.in'); reset(input);
85   assign(output,'trans.out'); rewrite(output);
86   read(n,m,k);
87   for i:=1 to n do read(fa[i]);
88   for i:=1 to n do read(c[i]);
89   main;
90   close(input); close(output);
91 end.

转载于:https://www.cnblogs.com/datam-cy/archive/2012/05/22/2513782.html

这篇关于【NOI2008】 奥运物流的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/364855

相关文章

京东物流查询|开发者调用API接口实现

快递聚合查询的优势 1、高效整合多种快递信息。2、实时动态更新。3、自动化管理流程。 聚合国内外1500家快递公司的物流信息查询服务,使用API接口查询京东物流的便捷步骤,首先选择专业的数据平台的快递API接口:物流快递查询API接口-单号查询API - 探数数据 以下示例是参考的示例代码: import requestsurl = "http://api.tanshuapi.com/a

AI 与大模型:物流行业的变革力量

一、物流行业的现状与挑战 物流行业在现代经济中扮演着至关重要的角色,但目前也面临着诸多挑战。 在效率方面,交通拥堵是一个突出问题。许多城市道路容量不足,无法满足日益增长的货物运输需求,导致运输时间延长。例如,在一些大城市,货物运输常常因交通拥堵而延迟,影响了整个供应链的效率。此外,信息不对称也严重影响了物流效率。供应商和购买方之间缺乏实时信息共享平台,双方无法准确了解货物的到达时间、配送状

使用Python海龟绘图画出奥运五环图

本套课程在线学习视频 ​​https://pan.quark.cn/s/3a470a7bbe67​​ Python的海龟绘图(Turtle Graphics)是一个非常有趣且易于使用的绘图模块,特别适合初学者学习编程和简单的图形绘制。在这篇博客中,我们将使用海龟绘图模块绘制奥运五环图。奥运五环图是由五个相互重叠的圆环组成的标志,代表五大洲的团结和奥林匹克精神。 准备工作 在开始绘图之前,请

巴西市场机械设备物流解决方案

巴西市场机械设备物流解决方案 巴西经济的持续增长,为各类机械设备的进口需求带来了巨大的市场机会。从工业设备到农业机械,从建筑器材到家用电器,巴西对高质量机械设备的需求日益增加。然而,复杂的海关手续、长时间的运输周期以及高昂的物流成本,常常让机械设备的出口商望而却步。为此,专业的机械设备海运,解决这些难题,确保设备顺利进入巴西市场。 巴西市场机械设备物流解决方案 内容与优势: 专业运

佳易王物流货运单据打印查询统计管理系统软件下载及打印样式模板操作教程

一、前言 佳易王物流货运单据打印查询统计管理系统软件下载及打印样式模板操作教程 1、佳易王物流管理系统可以打印物流单,查询,统计等。 2、可以在空白单上打印,也可以在卷纸上打印,可同时打印标签 二 、软件打印样式   上图为在空白单上打印,可以是两联单或三联单,纸张尺寸241*140 上图为卷纸打印,纸张尺寸为8CM宽卷纸 上图为标签打印, 物流单或标签打印内容可以定制

《物流工程与管理》是什么级别的期刊?是正规期刊吗?能评职称吗?

​问题解答 问:《物流工程与管理》是不是核心期刊? 答:不是,是知网收录的第一批认定学术期刊。 问:《物流工程与管理》级别? 答:国家级。主管单位: 全国商品养护科技情报中心站              主办单位: 中国仓储协会、全国商品养护科技情报中心站  问:《物流工程与管理》影响因子? 答:(2023版)复合影响因子:0.887 (2023版)综合影响因子:0.476 《物

基于JavaWeb开发的Java+SpringBoot+vue+element实现物流管理系统

基于JavaWeb开发的Java+SpringBoot+vue+element实现物流管理系统 🍅 作者主页 网顺技术团队 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 文末获取源码联系方式 📝 🍅 查看下方微信号获取联系方式 承接各种定制系统 📝 🚀🚀🚀精彩系列推荐 👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到哟 Java毕设项目精品实战案例《1000套》 感兴趣的可以

【项目实战】智能机械臂协同视觉辅助仓储物流管控平台

写在前面: 🌟 欢迎光临 清流君 的博客小天地,这里是我分享技术与心得的温馨角落。📝 个人主页:清流君_CSDN博客,期待与您一同探索 移动机器人 领域的无限可能。 🔍 本文系 清流君 原创之作,荣幸在CSDN首发🐒 若您觉得内容有价值,还请评论告知一声,以便更多人受益。 转载请注明出处,尊重原创,从我做起。 👍 点赞、评论、收藏,三连走一波,让我们一起养成好习惯😜 在这里,您将

千云物流 -低代码平台MySQL主从复制

主库操作 mysql配置搭建从库 环境准备 已经有安装的数据库服务外单独准备一台从库服务器保证新建立的从库服务器网络可达保证数据库的版本和主库一致 创建复制用户 CREATE USER 'replica_user'@'%' IDENTIFIED BY 'janle@etms';GRANT REPLICATION SLAVE ON *.* TO 'replica_user'@'%'

中锂天源卡车电瓶:绿色能源驱动未来物流

随着我国新能源汽车产业的飞速发展,作为新能源汽车核心部件的锂电池产业也得到了前所未有的关注。在这其中,中锂天源作为一家专业从事锂电池研发、生产、销售的企业,凭借其卓越的科技创新和产品质量,逐渐成为了卡车电瓶领域的一股强大力量。 中锂天源卡车电瓶,以其高安全性、高稳定性、长寿命、耐低温等特点,赢得了广大消费者的青睐。其采用的先进的锂电池技术,使得卡车电瓶在能量密度、续航里程等方面具有显著优