题目链接

思路:
<1>概率与期望
期望=情况①的值*情况①的概率+情况②的值*情况②的概率+……+情况n的值*情况n的概率
举个例子,抛一个骰子,每一面朝上的概率都是1/6,则这一个骰子落地后朝上的那一面的期望值就为:1*1/6+2*1/6+3*1/6+4*1/6+5*1/6+6*1/6=21/6=3.5
你们懂的(其实是我不怎么会)
<2>floyd
你们懂的(这一个我是会的)
<3>期望dp
dp[i][j][0]表示在前i个时间段,申请换了j个教室,第i个时间段不申请换教室时的最优解
dp[i][j][1]表示在前i个时间段,申请换了j个教室,第i个时间段申请换教室时的最优解
对于第x次申请,失败的概率为(1-k[x]),成功的概率即为k[x]
对于dp[i][j][0]可以由三种情况转移过来:
1.上一个时间段不申请
2.上一个时间段申请失败
3.上一个时间段申请成功
其中,第2、3种属于同一类
对于dp[i][j][1]可以由六种情况转移过来:
1.上一个时间段不申请,这一个时间段申请失败
2.上一个时间段不申请,这一个时间段申请成功
3.上一个时间段申请失败,这一个时间段申请失败
4.上一个时间段申请失败,这一个时间段申请成功
5.上一个时间段申请成功,这一个时间段申请失败
6.上一个时间段申请成功,这一个时间段申请成功
其中,第1、2种属于同一类,第3、4、5、6种属于同一类。
对于每一种情况,都将所属这一种情况的每一个操作的概率相乘,即可求出这一种情况出现的概率,再乘以相应两个课室之间的最短路径,就可以得出期望值。最后dp[n][1..m][0..1]中的最小值就是答案。
<4>反思
这道题的转移方程很长,然而我一开始并没有换行,然后就有了一个我看不出的错误,然后我提交上去就WA了,然后我冥思苦想一行一行对照题解,然后我还是没能找出错误,然后llx来了叫我对拍,然后我就开始对拍了,然后我就发现了错误,原来是一个地方忘了减一,然后我提交上去就A了,然后就没有然后了……
<完>
#include<iostream>
#include<cstdio>
#include<fstream>
#include<algorithm>
#include<string>
#include<sstream>
#include<cstring>
using namespace std;
const int INF=10000000;
int c[2005],d[2005],f[305][305];
double k[2005],dp[2005][2005][2];
int main()
{
int n=0,m=0,v=0,e=0;
double ans=INF;
scanf("%d%d%d%d",&n,&m,&v,&e);
if(n==1) { printf("0.00"); return 0; }
for(int i=1;i<=n;i++) scanf("%d",&c[i]);
for(int i=1;i<=n;i++) scanf("%d",&d[i]);
for(int i=1;i<=n;i++) scanf("%lf",&k[i]);
for(int i=1;i<=v;i++)//初始化邻接矩阵
for(int j=1;j<i;j++)
f[i][j]=f[j][i]=INF;
for(int i=1;i<=e;i++)
{
int a=0,b=0,w=0;
scanf("%d%d%d",&a,&b,&w);
f[a][b]=f[b][a]=min(f[a][b],w);//存边
}
for(int T=1;T<=v;T++)//floyd
for(int i=1;i<=v;i++)
for(int j=1;j<i;j++)
f[i][j]=f[j][i]=min(f[i][j],f[i][T]+f[T][j]);
for(int i=1;i<=n;i++)//dp数组初始化
for(int j=0;j<=m;j++)
dp[i][j][0]=dp[i][j][1]=INF;
dp[1][0][0]=dp[1][1][1]=0;//边界条件
for(int i=2;i<=n;i++)//dp
for(int j=0;j<=min(m,i);j++)
{
if(j>0) dp[i][j][1]=min(dp[i-1][j-1][0]+f[c[i-1]][c[i]]*(1-k[i])+f[c[i-1]][d[i]]*k[i],
dp[i-1][j-1][1]+f[c[i-1]][c[i]]*(1-k[i-1])*(1-k[i])+
f[c[i-1]][d[i]]*(1-k[i-1])*k[i]+
f[d[i-1]][c[i]]*k[i-1]*(1-k[i])+
f[d[i-1]][d[i]]*k[i-1]*k[i]);
dp[i][j][0]=min(dp[i-1][j][0]+f[c[i-1]][c[i]],
dp[i-1][j][1]+f[c[i-1]][c[i]]*(1-k[i-1])+
f[d[i-1]][c[i]]*k[i-1]);
if(i==n) ans=min(ans,min(dp[i][j][0],dp[i][j][1]));//维护最小期望值
}
printf("%.2lf",ans);//四舍五入精确到小数点后2位,输出
return 0;
}

Luogu P1850 [NOIp2016提高组]换教室 | 期望dp的更多相关文章

  1. 题解 P1850 [NOIP2016 提高组] 换教室

    做完这道题才略微感觉自己懂了一点关于概率与期望的知识QAQ... 一:关于概率与期望的定义 转载节选于blog 1.什么是数学期望? 数学期望亦称期望.期望值等.在概率论和统计学中,一个离散型随机变量 ...

  2. [NOIp2016提高组]换教室

    题目大意: 有n节课,第i节课在c[i]上课,同时d[i]也有一节课d[i]. 你有权利向教务处发出m次申请把自己的教室改到d[i],相应的批准概率是k[i]. 教室是图上的一些点,其中每条边都有边权 ...

  3. 洛谷 1850 NOIP2016提高组 换教室

    [题解] 先用floyed处理出两点间的最短路. 设f[i][j][k]表示走到第i个教室,总共换了j次,当前换或者不换,期望的最小移动距离. 分情况讨论来转移即可. #include<cstd ...

  4. 换教室(期望+DP)

    换教室(期望+DP) \(dp(i,j,1/0)\)表示第\(i\)节课,申请了\(j\)次调换,这节课\(1/0\)调换. 换教室 转移的时候考虑: 上次没申请 这次也没申请 加上\(dis(fr[ ...

  5. Luogu P1850 换教室(期望dp)

    P1850 换教室 题意 题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有\(2n\)节课程安排在\(n\)个时间段上.在第\(i(1\l ...

  6. bzoj4720: [Noip2016]换教室(期望dp)

    4720: [Noip2016]换教室 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 1294  Solved: 698[Submit][Status ...

  7. P1850 换教室 期望dp

    P1850 换教室 题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有 2n2n 节课程安排在 nn 个时间段上.在第 ii(1 \leq ...

  8. 【bzoj4720】[NOIP2016]换教室 期望dp

    题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程.在可以选择的课程中,有2n节课程安排在n个时间段上.在第i(1≤i≤n)个时间段上,两节内容相同的课程同时在不同的 ...

  9. 【BZOJ4720】【NOIP2016】换教室 [期望DP]

    换教室 Time Limit: 20 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description Input 第一行四个整数n,m,v ...

随机推荐

  1. 什么是云效 Projex,云效Projex企业级高效研发项目管理平台

    云效项目协作Projects是一款企业级高效研发项目管理平台, 提供了快速实践的敏捷研发项目管理机制,提供对需求.迭代.缺陷各个维度的协同管理以及相关的统计报告,让研发团队高效协作.践行敏捷并持续交付 ...

  2. Java基础系列(28)- 方法的定义和调用

    方法的定义 Java的方法类似于其他语言的函数,是一段用来完成特定功能的代码片段,一般情况下,定义一个方法包含以下语法: 修饰符 返回值类型 方法名(参数类型 参数名){ -- 方法体 -- retu ...

  3. Linux系列(13) - CentOs 8 配置静态IP

    step-1 vim etho的配置文件 [root#localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-eth0 step-2 新增修改以下 ...

  4. 如何在word中美观地插入编程代码

    零.缘起 在整理Java笔记时,想把代码直接贴到word文档中,原来一直截图很麻烦,所以找到以下方法. 思想:问题比答案更重要!你能想到问题,才知道去百度搜索. 一.打开网站 http://www.p ...

  5. LR11可打开网页,但录制为空

    环境:WIN7+LR11+360安全浏览器9.0 LR11可打开网页,但录制为空解决方案:(3步) 1. tools-Recording Options -->Network-->Port ...

  6. Kafka分区策略

    Kafka分区策略 所谓分区策略是决定生产者将消息发送到哪个分区的算法.Kafka 为我们提供了默认的分区策略,同时它也支持你自定义分区策略. 常见的分区策略包含以下几种:轮询策略.随机策略 .按消息 ...

  7. P7600-[APIO2021]封闭道路【堆,dp】

    正题 题目链接:https://www.luogu.com.cn/problem/P7600 题目大意 给出\(n\)个点的一棵树,边有边权,对于每个\(k\)求去掉最小边权和的点使得每个点的度数都不 ...

  8. HTML元素的三种类型及其转换

    HTML元素的三大类型 1.块元素 可以设置宽高大小,默认宽度为100%,并且独占一行. 例如:p ul li h1~h6 div form table 2.内联(行内)元素 无法设置宽高,元素大小随 ...

  9. Springboot在有锁的情况下如何正确使用事务

    1. 概述 老话说的好:想要赚钱,就去看看有钱人有什么需求,因为有钱人钱多,所以赚的多. 言归正传,在Java项目的研发中,"锁"这个词并不陌生,最经典的使用场景是商品的超卖问题. ...

  10. HBase基础

    Hadoop生态系统 HBase简介 HBase – Hadoop Database,是一个高可靠性.高性能.面向列.可伸缩.实时读写的分布式数据库 利用Hadoop HDFS作为其文件存储系统,利用 ...