【bzoj4720】[NOIP2016]换教室 期望dp
题目描述
输入
输出
样例输入
3 2 3 3
2 1 2
1 2 1
0.8 0.2 0.5
1 2 5
1 3 3
2 3 1
样例输出
2.80
题解
不是很难想的floyd+期望dp
f[i][j]表示前i门课程用j次机会,且第i门课程不申请换教室的最小期望,
g[i][j]表示前i门课程用j次机会,且第i门课程申请换教室的最小期望。
先用floyd求出任意两点的距离,
然后就是推来推去,不难推。
但最坑的就是:
这尼玛有重边。。。尼玛有重边。。。玛有重边。。。有重边。。。重边。。。边。。。
(题目也没说没有重边呀。。。)
注意处理。
还有memset不能用于double数组,不然会炸得很惨。
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int c[2001] , d[2001] , map[301][301];
double p[2001] , f[2001][2001] , g[2001][2001];
int main()
{
int n , m , v , e , i , j , k , x , y , z;
double ans = 1000000000;
scanf("%d%d%d%d" , &n , &m , &v , &e);
for(i = 1 ; i <= n ; i ++ )
scanf("%d" , &c[i]);
for(i = 1 ; i <= n ; i ++ )
scanf("%d" , &d[i]);
for(i = 1 ; i <= n ; i ++ )
scanf("%lf" , &p[i]);
for(i = 1 ; i <= v ; i ++ )
{
for(j = 1 ; j <= v ; j ++ )
map[i][j] = 1000000000;
map[i][i] = 0;
}
for(i = 1 ; i <= e ; i ++ )
{
scanf("%d%d%d" , &x , &y , &z);
map[x][y] = map[y][x] = min(map[x][y] , z);
}
for(k = 1 ; k <= v ; k ++ )
for(i = 1 ; i <= v ; i ++ )
for(j = 1 ; j <= v ; j ++ )
if(map[i][j] > map[i][k] + map[k][j])
map[i][j] = map[i][k] + map[k][j];
for(i = 1 ; i <= n ; i ++ )
for(j = 0 ; j <= m ; j ++ )
f[i][j] = g[i][j] = 1000000000;
f[1][0] = g[1][1] = 0;
for(i = 2 ; i <= n ; i ++ )
{
f[i][0] = f[i - 1][0] + map[c[i - 1]][c[i]];
for(j = 1 ; j <= m ; j ++ )
{
f[i][j] = min(f[i - 1][j] + map[c[i - 1]][c[i]] ,
g[i - 1][j] + map[c[i - 1]][c[i]] * (1 - p[i - 1])
+ map[d[i - 1]][c[i]] * p[i - 1]);
g[i][j] = min(f[i - 1][j - 1] + map[c[i - 1]][c[i]] * (1 - p[i])
+ map[c[i - 1]][d[i]] * p[i] ,
g[i - 1][j - 1] + map[c[i - 1]][c[i]] * (1 - p[i - 1]) * (1 - p[i])
+ map[d[i - 1]][c[i]] * p[i - 1] * (1 - p[i])
+ map[c[i - 1]][d[i]] * (1 - p[i - 1]) * p[i]
+ map[d[i - 1]][d[i]] * p[i - 1] * p[i]);
}
}
for(i = 0 ; i <= m ; i ++ )
ans = min(ans , min(f[n][i] , g[n][i]));
printf("%.2lf\n" , ans);
return 0;
}
【bzoj4720】[NOIP2016]换教室 期望dp的更多相关文章
- bzoj4720: [Noip2016]换教室(期望dp)
4720: [Noip2016]换教室 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1294 Solved: 698[Submit][Status ...
- 【bzoj4720】[Noip2016]换教室 期望dp+最短路
Description 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程.在可以选择的课程中,有2n节 课程安排在n个时间段上.在第i(1≤i≤n)个时间段上,两节内容相同的 ...
- JZYZOJ1457 [NOIP2016]换教室 期望dp 动态规划 floyd算法 最短路
http://172.20.6.3/Problem_Show.asp?id=1457 我不知道为什么我倒着推期望只有80分,所以我妥协了,我对着题解写了个正的,我有罪. #include<cst ...
- 洛谷1850(NOIp2016) 换教室——期望dp
题目:https://www.luogu.org/problemnew/show/P1850 状态里记录的是”上一回有没有申请“,而不是”上一回申请成功否“,不然“申请 j 次”就没法转移了. dou ...
- [NOIP2016]换教室 期望dp
先弗洛伊德,然后把状态拆分遗传 #include<iostream> #include<cstdio> #include<cstring> #include< ...
- 洛谷P1850 [noip2016]换教室——期望DP
题目:https://www.luogu.org/problemnew/show/P1850 注释掉了一堆愚蠢,自己还是太嫩了... 首先要注意选或不选是取 min 而不是 /2 ,因为这里的选或不选 ...
- 换教室(期望+DP)
换教室(期望+DP) \(dp(i,j,1/0)\)表示第\(i\)节课,申请了\(j\)次调换,这节课\(1/0\)调换. 换教室 转移的时候考虑: 上次没申请 这次也没申请 加上\(dis(fr[ ...
- 【BZOJ4720】【NOIP2016】换教室 [期望DP]
换教室 Time Limit: 20 Sec Memory Limit: 512 MB[Submit][Status][Discuss] Description Input 第一行四个整数n,m,v ...
- 2018.08.30 bzoj4720: [Noip2016]换教室(期望dp)
传送门 一道无脑的期望dp. 用f[i][j][0/1]表示前i堂课提出了j次申请且第i堂课没有(有)提出申请. 这样就可以状态转移了. 然而这题状态转移方程有点长... (主要是情况多... 代码: ...
随机推荐
- POJ2431_Expedition_KEY
题目传送门 由题目可得,在一条路上有N个加油站,在距离终点a[i](细节)的位置上,你需要通过长度为L的路,油箱的容量是无限的,但是初始只有P点油,经过每个加油站时可以选择加b[i]的油,问最少加油几 ...
- 成都Uber优步司机奖励政策(3月24日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- centos7 的防火墙命令调整了
CentOS 7.0默认使用的是firewall作为防火墙,这里改为iptables防火墙.firewall:systemctl start firewalld.service#启动firewalls ...
- Chromium添加一段新字符串
参考:https://groups.google.com/a/chromium.org/forum/#!searchin/chromium-dev/tclib%7Csort:relevance/chr ...
- hdu1231最大连续子序列(动态规划)
最大连续子序列 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...
- TPO-16 C1 Reserve the room for a rehearsal
TPO-16 C1 Reserve the room for a rehearsal 第 1 段 1.Listen to a conversation between a Student and a ...
- webservice调用天气
class WebServiceHelper { /// <summary> /// 动态调用WebService /// </summary> /// <param n ...
- java实现遍历一个字符串的每一个字母(总结)
基础:牢记字符串操作的各种方法: String s = "aaaljlfeakdsflkjsadjaefdsafhaasdasd"; // 出现次数 int num = ...
- 凸包算法(Graham扫描法)详解
先说下基础知识,不然不好理解后面的东西 两向量的X乘p1(x1,y1),p2(x2,y2) p1Xp2如果小于零则说明 p1在p2的逆时针方向 如果大于零则说明 p1在p2的顺时针方向 struct ...
- 虚拟机下 rm -rf / 尝试
环境:虚拟机 系统版本:centOS 5.8.centOS 6.5 1. root权限:rm -rf / 2. root权限:rm -rf /* 测试结果:5.8下执行命令1,2,根目录文件被删除,系 ...