【洛谷】P4202 [NOI2008]奥运物流

感觉有点降智

首先设环长为\(len\),很容易推导出

\[R(1) = \frac{\sum_{i = 1}^{N} C_{i} k^{dep[i]}}{1 - k^{len}}
\]

我好像觉得似乎\(len\)越大底下越小了,太降智了,len越大底下越大

所以环长越小越好,所以我们如果动了一条环边,就是把它尽量往1连

枚举环上,强制要求环上上的点不选,除开1到1的后继的那条边,我们就获得了一棵树

我们希望\(dp\)出改了m个点最大是多少,显然改就一定直接连到1

设\(f[u][j][d]\)为\(u\)这个点,子树里改了\(j\)个点,我们硬点\(u\)到\(1\)的距离是\(d\)

转移的话分\(u\)有没有被连到1

如果被连到1了,那么就从\(max(f[v][k][1],f[v][k][2])\)转移过来,要加上\(C_{u} \times K\)

否则就从\(max(f[v][k][d + 1],f[v][k][1])\)转移过来,要加上\(C_{u} \times K^{d}\)

第二维是个背包,直接做就行了

#include <bits/stdc++.h>
#define fi first
#define se second
#define pii pair<int,int>
#define mp make_pair
#define pb push_back
#define space putchar(' ')
#define enter putchar('\n')
#define eps 1e-10
#define ba 47
#define MAXN 5005
//#define ivorysi
using namespace std;
typedef long long int64;
typedef unsigned int u32;
typedef double db;
template<class T>
void read(T &res) {
res = 0;T f = 1;char c = getchar();
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 +c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
int N,M;
int fa[65];
db K[65],C[65],f[65][65][65],g[65];
bool nouse[65];
void dfs(int u,int dep) {
for(int v = 2 ; v <= N ; ++v) {
if(fa[v] == u) dfs(v,dep + 1);
}
for(int d = dep ; d >= min(dep,2) ; --d) {
memset(g,0,sizeof(g));
for(int v = 1 ; v <= N ; ++v) {
if(fa[v] == u) {
for(int j = M ; j >= 0 ; --j) {
for(int k = j ; k >= 0 ; --k) {
g[j] = max(g[j],g[k] + max(f[v][j - k][d + 1],f[v][j - k][1]));
}
}
}
}
for(int j = 0 ; j <= M ; ++j) f[u][j][d] = g[j] + C[u] * K[d];
}
if(!nouse[u] && fa[u] != 1) {
memset(g,0,sizeof(g));
for(int v = 1 ; v <= N ; ++v) {
if(fa[v] == u) {
for(int j = M ; j >= 0 ; --j) {
for(int k = j; k >= 0 ; --k) {
g[j] = max(g[j],g[k] + max(f[v][j - k][2],f[v][j - k][1]));
}
}
}
}
for(int j = 0 ; j < M ; ++j) f[u][j + 1][1] = g[j] + C[u] * K[1];
}
}
void Init() {
read(N);read(M);scanf("%lf",&K[1]);
for(int i = 1 ; i <= N ; ++i) {
read(fa[i]);
}
K[0] = 1;
for(int i = 2 ; i <= N ; ++i) {
K[i] = K[i - 1] * K[1];
}
for(int i = 1 ; i <= N ; ++i) {
scanf("%lf",&C[i]);
}
}
void Solve() {
int p = 1;
db ans = 0;
for(int len = 2 ; len ; ++len) {
p = fa[p];
if(p == 1) break;
memset(nouse,0,sizeof(nouse));
int t = 1,l = 0;
while(l != len) {
nouse[t] = 1;
t = fa[t];
++l;
}
int rec = 0;
if(fa[p] != 1) {--M;rec = fa[p];fa[p] = 1;}
memset(f,0,sizeof(f));
dfs(1,0);
db res = f[1][M][0] / (1 - K[len]);
ans = max(ans,res);
if(rec) {++M;fa[p] = rec;} }
printf("%.2lf\n",ans);
}
int main(){
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Init();
Solve();
}

【洛谷】P4202 [NOI2008]奥运物流的更多相关文章

  1. bzoj 1065: [NOI2008] 奥运物流

    1065: [NOI2008] 奥运物流 Description 2008北京奥运会即将开幕,举国上下都在为这一盛事做好准备.为了高效率.成功地举办奥运会,对物流系统 进行规划是必不可少的.物流系统由 ...

  2. [NOI2008]奥运物流

    题目 洛谷 BZOJ 做法 单环有向图毒瘤题 不考虑环和改变后继:\(\sum\limits{i=1}^n C_i\cdot K^{dep(i)}\) 考虑环无穷等比求极m:\(R(1)=\sum\l ...

  3. 1065: [NOI2008]奥运物流 - BZOJ

    Sample Input4 1 0.52 3 1 310.0 10.0 10.0 10.0Sample Output30.00 推荐题解:http://blog.csdn.net/whjpji/art ...

  4. 洛谷P3980 [NOI2008]志愿者招募

    题解 最小费用最大流 每一天是一条边\((inf-a[i], 0)\) 然后对于一类志愿者, 区间两端连一条\((inf, c[i])\) \(S\)向第一个点连\((inf, 0)\) 最后一个点向 ...

  5. 【洛谷 P1772】 [ZJOI2006]物流运输(Spfa,dp)

    题目链接 \(g[i][j]\)表示不走在\(i\text{~}j\)时间段中会关闭的港口(哪怕只关\(1\)天)从\(1\)到\(m\)的最短路. \(f[i]\)表示前\(i\)天的最小花费.于是 ...

  6. 洛谷 P1477 [NOI2008]假面舞会

    题目链接 题目描述 一年一度的假面舞会又开始了,栋栋也兴致勃勃的参加了今年的舞会. 今年的面具都是主办方特别定制的.每个参加舞会的人都可以在入场时选择一 个自己喜欢的面具.每个面具都有一个编号,主办方 ...

  7. 【BZOJ1065】【NOI2008】奥运物流(动态规划)

    [BZOJ1065][NOI2008]奥运物流(动态规划) 题面 BZOJ 洛谷 题解 先不考虑环的情况,于是变成了一棵树. 这样子我们答案的贡献是\(\sum_{i=1}^nC_i\times k^ ...

  8. 【洛谷】P3980 [NOI2008]志愿者招募

    [洛谷]P3980 [NOI2008]志愿者招募 我居然现在才会用费用流解线性规划-- 当然这里解决的一类问题比较特殊 以式子作为点,变量作为边,然后要求就是变量在不同的式子里出现了两次,系数一次为+ ...

  9. 洛谷 P1656 炸铁路

    P1656 炸铁路 题目提供者kkksc03 标签图论搜索/枚举洛谷原创 难度普及/提高- 题目描述 因为某国被某红色政权残酷的高压暴力统治.美国派出将军uim,对该国进行战略性措施,以解救涂炭的生灵 ...

随机推荐

  1. svn 外部引用别的项目文件

    建立了一个文件目录E:\My\myproject 想在该目录下有一个文件夹引用别的工程的文件. 1.在E:\My\myproject 空白处右键属性. 2.点击Properties,弹出 3.点击ne ...

  2. JS 时间转换函数 字符串时间转换毫秒(互转)

    字符串转化为日期 let util = function(){ Date.prototype.Format = function(fmt) { var o = { "M+" : t ...

  3. SpringAOP配置与使用(示例)

    1.pom.xml追加 spring-aspects aspectjrt 为控制器以外的类织入切面 2.新建spring-aop.xml <?xml version="1.0" ...

  4. Editor

    E. Editor 我们把"("用1表示,")"用-1表示,其余字母用0表示,这样形成的一个数组,我们求出它的前缀和sum[],只有当\(sum[n]==0\) ...

  5. c标签forEach

    <c:forEach items="${requestScope.getUserMenuModelList}" var="item" varStatus= ...

  6. tmux 入门踩坑记录

    软件安装 sudo apt-get install tmux 1. 分割左右窗口 ^b -> % 运行 tmux 新建一个 tmux 的会话(session),此时窗口唯一的变化是在底部会出现一 ...

  7. Python——装饰器(Decorator)

    1.什么是装饰器? 装饰器放在一个函数开始定义的地方,它就像一顶帽子一样戴在这个函数的头上.和这个函数绑定在一起.在我们调用这个函数的时候,第一件事并不是执行这个函数,而是将这个函数做为参数传入它头顶 ...

  8. 有效管理进程的几个linux命令

    一般来说,应用程序进程的生命周期有三种主要状态:启动.运行和停止.如果我们想成为称职的管理员,每个状态都可以而且应该得到认真的管理.这八个命令可用于管理进程的整个生命周期. 启动进程 启动进程的最简单 ...

  9. Flutter移动电商实战 --(34)列表页_小BUG的修复

    当高粱酒的子类没有数据返回的时候就会报错. 解决接口空数据报错的问题 没有数据的时候,给用户一个友好的提示, 我们没有数据的时候还要告诉用户,提示一下他没有数据,在我们的右侧列表的build方法内去判 ...

  10. JavaWeb MySQL 实现登录验证

    0. 环境准备 项目创建: IDEA 创建 Servlet 项目详细步骤:https://www.jianshu.com/p/386a79d16e05 导入 MySQL 驱动包: Java MySQL ...