http://172.20.6.3/Problem_Show.asp?id=1457

我不知道为什么我倒着推期望只有80分,所以我妥协了,我对着题解写了个正的,我有罪。

 #include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<queue>
using namespace std;
const int maxn=;
int t,k,n,m;
int c[][maxn]={};
int dis[][]={};
int vis[maxn]={};
double f[maxn][maxn][];
double ke[maxn]={};
int main(){
//freopen("wtf.in","r",stdin);
scanf("%d%d%d%d",&t,&k,&n,&m);
int x,y,v;
for(int i=;i<=t;i++){
scanf("%d",&c[][i]);
}
for(int i=;i<=t;i++){
scanf("%d",&c[][i]);
}
for(int i=;i<=t;i++){
scanf("%lf",&ke[i]);
}
memset(dis,,sizeof(dis));
for(int i=;i<=n;i++) dis[i][i]=;
for(int i=;i<=m;i++){
scanf("%d%d%d",&x,&y,&v);
dis[x][y]=min(dis[x][y],v);
dis[y][x]=dis[x][y];
}
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
if(i==j)continue;
for(int w=;w<=n;w++){
if(dis[j][i]+dis[i][w]<dis[j][w]){
dis[j][w]=dis[j][i]+dis[i][w];
}
}
}
}
for(int i=;i<=n;i++) dis[i][]=dis[][i]=;
for(int i=;i<=t;i++){
for(int j=;j<=k;j++){
f[i][j][]=20000000000.0;
f[i][j][]=20000000000.0;
}
}double ans=f[][][];
f[][][]=f[][][]=;
for(int i=;i<=t;i++){
int ma=min(i,k);
f[i][][]=f[i-][][]+dis[c[][i-]][c[][i]];
for(int j=;j<=ma;j++){
f[i][j][]=min(f[i-][j][]+dis[c[][i-]][c[][i]],f[i-][j][]+dis[c[][i-]][c[][i]]*ke[i-]+dis[c[][i-]][c[][i]]*(1.0-ke[i-]));
f[i][j][]=min(f[i-][j-][]+dis[c[][i-]][c[][i]]*ke[i]+dis[c[][i-]][c[][i]]*(-ke[i]),
f[i-][j-][]+dis[c[][i-]][c[][i]]*ke[i]*ke[i-]+dis[c[][i-]][c[][i]]*ke[i-]*(1.0-ke[i])
+dis[c[][i-]][c[][i]]*(1.0-ke[i-])*ke[i]+dis[c[][i-]][c[][i]]*(1.0-ke[i])*(1.0-ke[i-]));
}
}
for(int i=;i<=k;i++){
ans=min(ans,min(f[t][i][],f[t][i][]));
}
printf("%.2f",ans);
return ;
}

JZYZOJ1457 [NOIP2016]换教室 期望dp 动态规划 floyd算法 最短路的更多相关文章

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

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

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

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

  3. 【bzoj4720】[Noip2016]换教室 期望dp+最短路

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

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

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

  5. [NOIP2016]换教室 期望dp

    先弗洛伊德,然后把状态拆分遗传 #include<iostream> #include<cstdio> #include<cstring> #include< ...

  6. 洛谷P1850 [noip2016]换教室——期望DP

    题目:https://www.luogu.org/problemnew/show/P1850 注释掉了一堆愚蠢,自己还是太嫩了... 首先要注意选或不选是取 min 而不是 /2 ,因为这里的选或不选 ...

  7. 换教室(期望+DP)

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

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

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

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

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

随机推荐

  1. 【BZOJ】1705: [Usaco2007 Nov]Telephone Wire 架设电话线

    [题意]给定一排n根杆高度hi,一个常数C,杆升高x的代价为x^2,相邻两杆之间架设电话线代价为高度差*C,求总代价最小. [算法]DP+辅助数组优化 [题解]令f[i][j]表示第i根杆高度为j的最 ...

  2. python初步学习-python运算符

    算数运算符 操作 描述 例子 + 加法-对操作符的两侧增加值 a+b=30 - 减法 a-b=30 * 乘法 a * b = 30 / 除法 a/b=30 % 模(取余) a%b=30 ** 指数(幂 ...

  3. 表格td内容超出宽度显示... table-layout: fixed;

    td宽度用百分比固定好的时候,即使设置了 white-space:nowrap;/*文本不会换行,在同一行显示*/ overflow:hidden;超出隐藏 text-overflow:ellipsi ...

  4. bzoj 1854 游戏 二分图匹配 || 并查集

    题目链接 Description lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的 ...

  5. Python3 hashlib模块和hmac 模块(加密)

    hashlib 是一个提供了一些流行的hash算法的 Python 标准库.其中所包括的算法有 md5, sha1, sha224, sha256, sha384, sha512等常用算法 MD5加密 ...

  6. Exploring Qualcomm's TrustZone Implementation

    转自  http://bits-please.blogspot.com/2015/08   (需要FQ, 狗日的墙) In this blog post, we'll be exploring Qua ...

  7. python并发模块之concurrent.futures(二)

    python并发模块之concurrent.futures(二) 上次我们简单的了解下,模块的一些基本方法和用法,这里我们进一步对concurrent.futures做一个了解和拓展.上次的内容点这. ...

  8. hadoop安装 伪分布

    伪分布hadoop 安装总结 准备,在配置中hadoop用的9000端口,如果有其它软件用着这个端口,建议更换后再进行下面配置,以避免出现错误.比如php-fpm经常使用9000端口. 一.下载jdk ...

  9. EOS.IO技术学习

    如今很火的项目EOS的学习,以下主要的内容是基于白皮书 参考: http://chainx.org/paper/index/index/id/20.html EOS.IO软件引入了一种新的块链架构,旨 ...

  10. [LabVIEW架构]ActorFramework(一)

    前言 小黑结婚回来第二周了,每天忙于程序设计,时间比较紧张,所以文章一直没出来,也算憋大招了. 近期小黑将与大家一起认识一下ActorFramework,既是对自己一段时间写AF程序的总结,也是梳理, ...