题目很长,是一道概率dp题,一般需要逆推,但这题结局不确定所以要顺推。

用f[i][j][k],i表示第i段时间,j表示用了j次申请,k就表示这轮是否用申请。

那么要求min(f[n][0~m][0],f[n][0~m][1])

状态转移方程有点麻烦,需要细心。

①前一个不需要申请,当前的时间也不需要申请。这个最容易推出来f[i][j][0]=min(f[i][j][0],(f[i-1][j][0]+dis[c[i-1]][c[i]]))×1.0)

②当前j>=1,那么至少可以申请一次。也就是可以前一个时间没申请,当前申请。或者前一个时间申请,当前没申请。

③当前j>=2,那么就可以考虑前一段时间也申请了。因为申请分成功和失败,所以这里有4个不同的状况要考虑。分别是:

申请成功->申请成功

申请成功->申请失败

申请失败->申请成功

申请失败->申请失败

代码中的_11s表示前一段时间申请了,这一次也申请了,并申请成功。1表示申请了,0表示没申请。s表示成功,f表示失败。

代码如下:

#include <iostream>
#include <string.h>
#include <stdio.h>
using namespace std;
typedef long long ll; int n,m,v,e;
int c[],d[];
double k[];
int dis[][],a,b,cc;
double f[][][];
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 i=;i<=v;++i)dis[i][i]=;
for(int i=;i<=e;++i){
scanf("%d%d%d",&a,&b,&cc);
dis[a][b]=dis[b][a]=min(dis[a][b],cc);
}
for(int kk=;kk<=v;++kk)
for(int i=;i<=v;++i)
for(int j=;j<=v;++j)
dis[i][j]=dis[j][i]=min(dis[i][j],dis[i][kk]+dis[kk][j]);
for(int i=;i<=n;++i)for(int j=;j<=m;++j)
f[i][j][]=f[i][j][]=0x3f3f3f3f;
f[][][]=f[][][]=0.0;
for(int i=;i<=n;++i){
for(int j=;j<=min(i,m);++j){
f[i][j][]=min(f[i][j][],f[i-][j][]+dis[c[i-]][c[i]]);
if(j>=){
double _10s=(f[i-][j][]+1.0*dis[d[i-]][c[i]])*k[i-];
double _10f=(f[i-][j][]+1.0*dis[c[i-]][c[i]])*(1.0-k[i-]);
f[i][j][]=min(f[i][j][],_10s+_10f);
double _01s=(f[i-][j-][]+1.0*dis[c[i-]][d[i]])*k[i];
double _01f=(f[i-][j-][]+1.0*dis[c[i-]][c[i]])*(1.0-k[i]);
f[i][j][]=min(f[i][j][],_01s+_01f);
}
if(j>=){
double _11ss,_11ff,_11sf,_11fs;
_11ss=(f[i-][j-][]+dis[d[i-]][d[i]])*k[i-]*k[i];
_11ff=(f[i-][j-][]+1.0*dis[c[i-]][c[i]])*(1.0-k[i-])*(1.0-k[i]);
_11fs=(f[i-][j-][]+1.0*dis[c[i-]][d[i]])*(1.0-k[i-])*k[i];
_11sf=(f[i-][j-][]+1.0*dis[d[i-]][c[i]])*k[i-]*(1.0-k[i]);
double tmp=_11ss+_11ff+_11sf+_11fs;
f[i][j][]=min(f[i][j][],tmp);
}
}
}
double ans=0x3f3f3f3f;
for(int i=;i<=m;++i)
ans=min(ans,min(f[n][i][],f[n][i][]));
printf("%.2lf\n",ans);
return ;
}

BZOJ4720-换教室的更多相关文章

  1. 【bzoj4720】[NOIP2016]换教室

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

  2. bzoj4720 / P1850 换教室(Floyd+期望dp)

    P1850 换教室 先用Floyd把最短路处理一遍,接下来就是重头戏了 用 f [ i ][ j ][ 0/1 ] 表示在第 i 个时间段,发出了 j 次申请(注意不一定成功),并且在这个时间段是否( ...

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

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

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

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

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

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

  6. [NOIP2016]换教室 D1 T3 Floyed+期望DP

    [NOIP2016]换教室 D1 T3 Description 对于刚上大学的牛牛来说, 他面临的第一个问题是如何根据实际情况中情合适的课程. 在可以选择的课程中,有2n节课程安排在n个时间段上.在第 ...

  7. [BZOJ 4720][NOIP 2016] 换教室

    记得某dalao立了"联赛要是考概率期望我直播吃键盘"的$flag$然后就有了这道题233333 4720: [Noip2016]换教室 Time Limit: 20 Sec  M ...

  8. [NOIp2016] 换教室

    题目类型:期望\(DP\) 传送门:>Here< 题意:现有\(N\)个时间段,每个时间段上一节课.如果不申请换教室,那么时间段\(i\)必须去教室\(c[i]\)上课,如果申请换课成功, ...

  9. luoguP1850 换教室

    luoguP1850 换教室 链接 https://www.luogu.org/problemnew/show/P1850 思路 状态很显然就是f[n][k][0/1] 前i次,用了k次机会,当前是在 ...

  10. BZOJ 4720 [Noip2016]换教室

    4720: [Noip2016]换教室 Description 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程.在可以选择的课程中,有2n节课程安排在n个时间段上.在第i( ...

随机推荐

  1. python之列表及其方法---整理集

    列表类,类名是list 通过list类创建对象,使用中括号 列表特性: 使用中括号括起来 中间用逗号分隔每个元素 元素可以是数字.字符串.布尔值.列表 列表中可以嵌套列表 列表中每个元素的下标从0开始 ...

  2. 19-04【mysql】transaction,autocommit

    本地使用mysql测试结果如下, 没有使用start transaction的情况下: 如果set autocommit=1,则每一条语句默认提交: 如果set autocommit=0,则这条语句默 ...

  3. c#: WebBrowser 禁止在新窗口打开链接

    项目中碰到此需求.几番比对,此为最好的解决方案,聊做备忘. 1.加入Microsoft Internet Controls引用: 项目右键->添加引用->COM->Microsoft ...

  4. 项目总结21:项目总结21:input实现多图上传(FormData)(上传OSS并保存数据库)

    项目总结21:input实现多图上传(FormData)(上传OSS并保存数据库) 备注:本案例,作为Demo,包含少量的项目业务逻辑,input多图上传的逻辑是完整的: 不废话直接上代码 1-前端标 ...

  5. 一篇教你看懂spring bean工厂和aop

    这篇文章为spring回顾总结的第二篇,本篇主要分为两个部分,分别是spring的bean工厂的实现.spring的aop实现原理,这两部分也是面试当中问的比较多的. spring的bean工厂的实现 ...

  6. MySQL索引原理以及查询优化

    转载自:https://www.cnblogs.com/bypp/p/7755307.html MySQL索引原理以及查询优化 一.介绍 1.什么是索引? 一般的应用系统,读写比例在10:1左右,而且 ...

  7. swift 关于FDFullscreenPopGesture的右滑返回

    关于导航栏右滑返回的工具库 FDFullscreenPopGesture 是 OC 版本,用了 runtime 等各种骚操作 关于 swift ,我在 UINavigationController 的 ...

  8. 【每日更新】【Redis学习】

    5. Redis订阅和发布模式和Redis事务 -------------------Redis事务------------------- 1.概念:     redis中的事务是一组命令的集合.事务 ...

  9. angular中文文档的滚动条样式

    个人感觉angular中文文档的滚动条样式非常棒,于是乎就扒了下来 https://www.angular.cn/ body::-webkit-scrollbar { /* 定义了滚动条整体的样式 * ...

  10. python实现随机森林、逻辑回归和朴素贝叶斯的新闻文本分类

    实现本文的文本数据可以在THUCTC下载也可以自己手动爬虫生成, 本文主要参考:https://blog.csdn.net/hao5335156/article/details/82716923 nb ...