[Luogu 1850] noip16 换教室

好久没有更博客了,先唠嗑一会,花了两天的空闲时间大致做完了昨年的noip真题

虽然在经过思考大部分题目都可出解(天天爱跑步除外),但是并不知道考试时候造化如何。

总之自己这段时间多做好事,多积攒RP,每天RP++

Description

Solution:

首先当你看完这个到题的时候,你应该想到先用floyd跑出任意两点的最短路,这个不解释

然后又是这种求期望值最小,很明显也会想到DP的做法

那么DP的方程?通过发现对于当前第i个课程教室的期望是跟前一个课程的选择与否有关的,

那么最后我们的状态可以表示为 f[n][m][0..1]

接下去就比较容易了,只是需要耐心仔细的分类讨论

1、当前的课不换的情况:

(1)上一节课也没换;

(2)上一节课换了----成功 or 不成功;

2、当前的课换的情况:

(1)当前课成功换了:

a、上一节课换了----上一节课成功 or 不成功

b、上一节课没换;

(2)当前的课换了失败:

a、上一节课换了----上一节课成功 or 不成功

b、上一节课没换;

最后总结一下就是

那么就完成了

注意:转移时候因为多次出现距离可预先用cc,cd,dc,dd来表示 c[i-1] 到 c[i] 等等的距离

 #include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
const int N=,M=;
int c[M],d[M],dis[N][N],x,y,z,n,m,v,e;
double f[M][M][],k[M];
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]);
for (int i=;i<=v;++i) for (int j=;j<=v;++j) dis[i][j]=1e9;
for (int i=;i<=e;++i)
scanf("%d%d%d",&x,&y,&z),dis[x][y]=dis[y][x]=min(dis[x][y],z);
for (int i=;i<=v;++i) dis[i][i]=;
for (int kkk=;kkk<=v;++kkk)
for (int i=;i<=v;++i) if (i!=kkk)
for (int j=;j<=v;++j)
if (i!=j&&j!=kkk) dis[i][j]=min(dis[i][kkk]+dis[kkk][j],dis[i][j]);
for (int i=;i<=n;++i) for (int j=;j<=m;++j) f[i][j][]=f[i][j][]=1e9;
f[][][]=f[][][]=0.00; f[][][]=0.00;
for (int i=;i<=n;++i){
int cc=dis[c[i-]][c[i]],cd=dis[c[i-]][d[i]],dc=dis[d[i-]][c[i]],dd=dis[d[i-]][d[i]];
f[i][][]=f[i-][][]+cc;
for (int j=;j<=min(i,m);++j){
f[i][j][]=min(f[i-][j][]+cc,f[i-][j][]+cc*(-k[i-])+dc*k[i-]); f[i][j][]=min(f[i-][j-][]+cd*k[i]+cc*(-k[i]),
f[i-][j-][]+cc*(-k[i-])*(-k[i])+cd*(-k[i-])*k[i]+
dc*k[i-]*(-k[i])+dd*k[i-]*k[i]);
}
}
double ans=1e9;
for (int i=;i<=m;++i)
ans=min(ans,min(f[n][i][],f[n][i][]));
printf("%.2lf",ans);
}

[Luogu 1850] noip16 换教室的更多相关文章

  1. 「 Luogu P1850 」 换教室

    解题思路 很明显的是个期望 $dp$. 先前想到 $dp[i][j]$ 表示第决策到第 $i$ 个时间段,已经进行了 $j$ 次申请,然后就没有然后了,因为这根本就没法转移啊,你又不知道前 $i-1$ ...

  2. 【Luogu】P1850换教室(期望DP)

    题目链接 又一道面向题解编程的恶心神题.真是叫人质壁分离…… 设f[i][j][k]表示考虑了前i节课,尝试了j次,当前申请结果为k时消耗的体力值. 对于f[i][j][0]有两种情况:一是我们的主角 ...

  3. Luogu 1580 [NOIP2016] 换教室

    先用Floyed做亮点之间的最短路,设计dp,记dp[i][j][0]为到第i节课,换了j次课,当前有没有换课达到的期望耗费体力最小值 方程(太长了还是看代码吧):dp[i][j][0]<-dp ...

  4. 洛谷1850(NOIp2016) 换教室——期望dp

    题目:https://www.luogu.org/problemnew/show/P1850 状态里记录的是”上一回有没有申请“,而不是”上一回申请成功否“,不然“申请 j 次”就没法转移了. dou ...

  5. Bzoj 4720 换教室 (期望DP)

    刚发现Bzoj有Noip的题目,只会换教室这道题..... Bzoj 题面:Bzoj 4720 Luogu题目:P1850 换教室 大概是期望DPNoip极其友好的一道题目,DP不怎么会的我想到了,大 ...

  6. [NOIP2016][luogu]换教室[DP]

    [NOIP2016] Day1 T3 换教室 ——!x^n+y^n=z^n 题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有 2n 节课程 ...

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

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

  8. Luogu P1850 [NOIp2016提高组]换教室 | 期望dp

    题目链接 思路: <1>概率与期望期望=情况①的值*情况①的概率+情况②的值*情况②的概率+--+情况n的值*情况n的概率举个例子,抛一个骰子,每一面朝上的概率都是1/6,则这一个骰子落地 ...

  9. luoguP1850 换教室

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

随机推荐

  1. UpLoadify在IE下兼容问题

    一.在IE9.IE10不能点击的问题解决 解决方法:进入uploadify的js文件中,搜索SWFUpload.prototype.getFlashHTML,找到它对应的语句,将方法全部替换为以下内容 ...

  2. 内核调试-perf introduction

    perf概念 perf_event Perf_events是目前在Linux上使用广泛的profiling/tracing工具,除了本身是内核(kernel)的组成部分以外,还提供了用户空间(user ...

  3. 爬虫之cookie

    什么是cookie: 在网站中,http请求是无状态的.也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户.cookie的出现就是为了解决这个问题,第一次登 ...

  4. 《零压力学Python》 之 第四章知识点归纳

    第四章(决策和循环)知识点归纳 if condition: indented_statements [ elif condition: Indented_statements] [else: Inde ...

  5. Ubuntu_linux系统与网络服务管理

    1.远程telnet联机:telnetd: 2.远程加密ssh联机:openssh: 3.webmin远程联机:webmin: 3.VNC远程图像界面控制:vino: 4.NAT网关服务器:iptab ...

  6. Linxu基础入门

    Linux命令大全:http://man.linuxde.net/ 创建目录 使用 mkdir 命令创建目录 mkdir $HOME/testFolder 切换目录 使用 cd 命令切换目录 cd $ ...

  7. 【IntelliJ IDEA】idea上安装Translation插件后,需要AppKey才能生效的解决方案

    使用idea安装的翻译插件translation,但是使用的时候并不友好 无奈,如果想使用翻译软件并且更方便的话,可以如下: 可以选择将translation进行卸载 清除缓存并进行重启 然后再启动之 ...

  8. C#关键字详解第一节

    abstract:抽象类: 他表达对问题或者实际中的事物,对象等所设计出的抽象概念,比如一个灵感.生物等,这些都是抽像, 但是他们往往也有具体的指向,比如生物圈有人类,猴子,老虎等等,老虎和人类是实际 ...

  9. selenium等待

    简介 在selenium操作浏览器的过程中,每一次请求url,selenium都会等待页面加载完成以后, 才会将操作权限在交给我们的程序. 但是,由于ajax和各种JS代码的异步加载问题,当一个页面被 ...

  10. spring入门笔记

    这是我自己学习韩顺平老师spring视频的笔记,个人认为初学spring的韩顺平老师的讲的很好,比较通俗易懂,资源地址我已经给了,可以自己配合视频看.主要介绍了ioc和aop,这也是spring框架最 ...