洛谷——P1850 换教室
P1850 换教室
有 2n 节课程安排在 nn 个时间段上。在第 i个时间段上,两节内容相同的课程同时在不同的地点进行,其中,牛牛预先被安排在教室 $c_i$ 上课,而另一节课程在教室 $d_i$ 进行。
在不提交任何申请的情况下,学生们需要按时间段的顺序依次完成所有的 n节安排好的课程。如果学生想更换第 i节课程的教室,则需要提出申请。若申请通过,学生就可以在第 i个时间段去教室 $d_i$ 上课,否则仍然在教室 $c_i$ 上课。
由于更换教室的需求太多,申请不一定能获得通过。通过计算,牛牛发现申请更换第 i节课程的教室时,申请被通过的概率是一个已知的实数 $k_i$,并且对于不同课程的申请,被通过的概率是互相独立的。
学校规定,所有的申请只能在学期开始前一次性提交,并且每个人只能选择至多 $m$ 节课程进行申请。这意味着牛牛必须一次性决定是否申请更换每节课的教室,而不能根据某些课程的申请结果来决定其他课程是否申请;牛牛可以申请自己最希望更换教室的 $m$ 门课程,也可以不用完这 mm 个申请的机会,甚至可以一门课程都不申请。
因为不同的课程可能会被安排在不同的教室进行,所以牛牛需要利用课间时间从一间教室赶到另一间教室。
牛牛所在的大学有 vv 个教室,有 e 条道路。每条道路连接两间教室,并且是可以双向通行的。由于道路的长度和拥堵程度不同,通过不同的道路耗费的体力可能会有所不同。 当第 i节课结束后,牛牛就会从这节课的教室出发,选择一条耗费体力最少的路径前往下一节课的教室。
现在牛牛想知道,申请哪几门课程可以使他因在教室间移动耗费的体力值的总和的期望值最小,请你帮他求出这个最小值。
设$dp[i][j][0]$表示前i节课换了j次且这一次没换的耗费体力值得期望和的最小值,
同理$dp[i][j][1]$表示前i节课换了j次且这一次换了的耗费体力值得期望和的最小值;
首先你换教室有可能成功,当然也有可能失败,那么你这一次的概率就等于上一次换或不换成功不成功,这一次换或不换成功不成功期望路径和的最小值。
分类讨论即可。
#include<bits/stdc++.h> #define N 2005
using namespace std; int n,m,V,E,c[N],d[N],dis[N][N];
double k[N],ans,dp[][][]; int main()
{
scanf("%d%d%d%d",&n,&m,&V,&E);
for(int i=;i<=n;i++) scanf("%d",&c[i]);
for(int i=;i<=n;i++) scanf("%d",&d[i]);
for(int i=;i<=n;i++) scanf("%lf",&k[i]); memset(dis,0x3f,sizeof(dis));
for(int u,v,w,i=;i<=E;i++){
scanf("%d%d%d",&u,&v,&w);
dis[u][v]=dis[v][u]=min(w,dis[u][v]);
}
//Floyd预处理
for(int K=;K<=V;K++){
for(int i=;i<=V;i++){
for(int j=;j<=V;j++){
dis[i][j]=min(dis[i][K]+dis[K][j],dis[i][j]);
}
}
} for(int i=;i<=V;i++) dis[i][i]=dis[i][]=dis[][i]=; memset(dp,0x7f,sizeof(dp));
dp[][][]=dp[][][]=;
for(int i=;i<=n;i++){
dp[i][][]=dp[i-][][]+dis[c[i-]][c[i]];
for(int j=;j<=min(i,m);j++){
int c1=c[i-],c2=c[i],d1=d[i-],d2=d[i];
dp[i][j][]=min(dp[i][j][],
min(dp[i-][j][]+dis[c1][c2],
dp[i-][j][]+dis[d1][c2]*k[i-]+dis[c1][c2]*(1.0-k[i-]))); dp[i][j][]=min(dp[i][j][],
min(dp[i-][j-][]+dis[c1][c2]*(1.0-k[i])+dis[c1][d2]*k[i],//上一次没换
dp[i-][j-][]+dis[d1][c2]*k[i-]*(1.0-k[i])//上一次换了成功且这一次没成功
+dis[d1][d2]*k[i-]*k[i]//上一次换了成功且这一次也成功
+dis[c1][d2]*(1.0-k[i-])*k[i]//上一次换了没成功且这一次成功
+dis[c1][c2]*(1.0-k[i-])*(1.0-k[i])));//上一次换了没成功且这一次也没成功
// printf("%.2lf %.2lf\n",dp[i][j][0],dp[i][j][1]);
}
} ans=0x7fffffff;
for(int i=;i<=m;i++)//从0开始,可以一次也不换
ans=min(ans,min(dp[n][i][],dp[n][i][])); printf("%.2lf",ans);
return ;
}
洛谷——P1850 换教室的更多相关文章
- 洛谷 P1850 换教室 解题报告
P1850 换教室 题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有\(2n\)节课程安排在\(n\)个时间段上.在第\(i(1≤i≤n) ...
- 洛谷 P1850 换教室
P1850 换教室 题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有 2n2n 节课程安排在 nn 个时间段上.在第 ii(1 \leq ...
- 洛谷P1850换教室
题目传送门 理解题意:给定你一个学期的课程和教室数量以及教室之间的距离还有换教室成功的概率,求一个学期走的距离的期望最小值 题目是有够恶心的,属于那种一看就让人不想刷的题目...很明显的动规,但是那个 ...
- 洛谷P1850 换教室
令人印象深刻的状态转移方程... f[i][j][0/1]表示前i个换j次,第i次是否申请时的期望. 注意可能有重边,自环. 转移要分类讨论,距离是上/这次成功/失败的概率乘相应的路程. 从上次的0/ ...
- 洛谷P1850 换教室(概率dp)
传送门 我的floyd竟然写错了?今年NOIP怕不是要爆零了? 这就是一个概率dp 我们用$dp[i][j][k]$表示在第$i$个时间段,已经申请了$j$次,$k$表示本次换或不换,然后直接暴力转移 ...
- 洛谷P1850 换教室 [noip2016] 期望dp
正解:期望dp 解题报告: 哇我发现我期望这块真的布星,可能在刷了点儿NOIp之后会去搞一波期望dp的题...感觉连基础都没有打扎实?基础概念都布星! 好那先把这题理顺了嗷qwq 首先我们看到期望就会 ...
- 洛谷P1850 换教室_数学期望_Floyd
调了一下午QAQ-让我对数学期望的理解又提升了一个层次. 首先,我们发现 v<=300v<=300v<=300 , 这样我们就可以用 FloydFloydFloyd 算法来 O(n3 ...
- bzoj4720 / P1850 换教室(Floyd+期望dp)
P1850 换教室 先用Floyd把最短路处理一遍,接下来就是重头戏了 用 f [ i ][ j ][ 0/1 ] 表示在第 i 个时间段,发出了 j 次申请(注意不一定成功),并且在这个时间段是否( ...
- P1850 换教室
P1850 换教室 现在有一张图, 有 \(v <= 300\) 个节点 你需要从 \(c_{1}\) 到 \(c_{2}\) 到 \(c_{n} (n <= 2000)\) 现在你有 \ ...
随机推荐
- python-----模糊搜索文件
告诉计算机文件在哪 → 使用路径描述位置 描述文件的特征 → 用条件判断来筛选 比对后打印文件名 → 用循环来实现逐个比对 #!/usr/bin/env python # -*- codi ...
- 洛谷 P1970 花匠 —— DP
题目:https://www.luogu.org/problemnew/show/P1970 普通的DP,f[i][0/1] 表示 i 处处于较小或较大的长度: 注意:1.树状数组向后 query 时 ...
- oracle中WMSYS.WM_CONCAT函数的版本差异
昨天在测试的时候发现,开发人员写的一段程序放在开发库中是好的,但是放在测试库中就会有问题.开发人员一直找不到问题的原因在哪里.于是就花了点时间协助开发人员来找问题的根本原因. 通过一些技术手段,定位到 ...
- bzoj2521
最小生成树+最小割 ...我太zz了,没看出来全体减1是一个加1,看见后就是sb题了... 我们发现根据克鲁斯卡尔的过程,我们把边从小到大加入,如果两点已经相连就跳过,那么我们把所有小于等于这条边的边 ...
- mysql workbench的简单使用
注意:即使server没有开启,也可以通过workbench进来编辑页面. 1.再开始程序找到mysql workbench,点击运行 2.t添加管理员链接mysql-------------前提是你 ...
- bzoj 1627: [Usaco2007 Dec]穿越泥地【bfs】
在洛谷上被卡了一个点开了O2才过= = bfs即可,为方便存储,把所有坐标+500 #include<iostream> #include<cstdio> #include&l ...
- 清北考前刷题day4早安
LI /* 没有考虑次大值有大于一个的情况 */ #include<iostream> #include<cstdio> #include<cstring> # ...
- xshell、xftp最新版下载方法
https://www.netsarang.com/download/main.html 登录邮箱打开第一个下载地址进行下载
- composer windows安装,使用新手入门[转]
原:https://blog.csdn.net/csdn_dengfan/article/details/54912039 一.前期准备: 1.下载安装包,https://getcomposer.or ...
- Android 性能优化(4)Optimizing Layout Hierarchies:用Hierarchy Viewer和Layoutopt优化布局
Optimizing Layout Hierarchies This lesson teaches you to Inspect Your Layout Revise Your Layout Use ...