【NOIP2016】换教室(DP,期望)
题意:
对于刚上大学的牛牛来说, 他面临的第一个问题是如何根据实际情况中情合适的课程。
在可以选择的课程中,有2n节课程安排在n个时间段上。在第 i ( 1≤ i≤n)个时同段上, 两节内容相同的课程同时在不同的地点进行, 其中, 牛牛预先被安排在教室 ci上课, 而另一节课程在教室 di进行。
在不提交任何申请的情况下,学生们需要按时间段的顺序依次完成所有的n节安排好的课程。如果学生想更换第i节课程的教室,则需要提出中情。若申请通过,学生就可以在第 i个时间段去教室 di上课, 否则仍然在教室 ci上课。
由于更换教室的需求太多, 申请不一定能获得通过。 通过计算, 牛牛发现申请更换第 i节课程的教室时, 中情被通过的概率是一个已知的实数 ki, 并且对于不同课程的申请, 被通过的概率是互相独立的。
学校规定, 所有的申请只能在学期开始前一次性提交, 并且每个人只能选择至多m节课程进行申请。 这意味着牛牛必须一次性决定是否申请更换每节课的教室, 而不能根据某些课程的申请结果来决定其他课程是否申请; 牛牛可以申请白己最希望更换教室的 m门课程,也可以不用完这m个中情的机会,甚至可以一门课程都不申请。
因为不同的课程可能会被安排在不同的教室进行, 所以牛牛需要利用课问时间从一间教室赶到另一间教室。
牛牛所在的大学有 v个教室,有 e条道路。每条道路连接两间教室, 并且是可以双向通行的。 由于道路的长度和拥;i者程度不同, 通过不同的道路耗费的体力可能会有所不同。当第i ( 1≤i≤n-1 )节课结束后,牛牛就会从这节课的教室出发,选择一条耗费体力最少的路径前往下一节课的教室。
现在牛牛想知道,申请哪几门课程可以使他因在教室问移动耗费的体力值的总和的期望值最小,请你帮他求出这个最小值
保证1≤n≤2000, 0≤m≤2000, 1≤v≤300, 0≤ e≤90000。
思路:萎靡的期望DP
dp[i,j,0/1]表示前i门申请j门(不一定通过),最后一门是否申请的最小期望
分四种情况讨论
V打成N毁一生
var dp:array[..,..,..]of double;
f:array[..,..]of double;
c,d:array[..]of longint;
g:array[..]of double;
n,m,v1,e1,i,j,k,x,y,z:longint;
ans:double; function min(x,y:double):double;
begin
if x<y then exit(x);
exit(y);
end; begin readln(n,m,v1,e1);
for i:= to n do read(c[i]);
for i:= to n do read(d[i]);
for i:= to n do read(g[i]);
for i:= to v1 do
for j:= to v1 do f[i,j]:=<<;
for i:= to v1 do f[i,i]:=;
for i:= to v1 do begin f[,i]:=; f[i,]:=; end;
for i:= to e1 do
begin
read(x,y,z);
f[x,y]:=min(f[x,y],z);
f[y,x]:=min(f[y,x],z);
end;
for i:= to v1 do
for j:= to v1 do
for k:= to v1 do
if(i<>j)and(i<>k)and(j<>k) then f[j,k]:=min(f[j,k],f[j,i]+f[i,k]);
for i:= to n do
for j:= to m do
begin
dp[i,j,]:=<<; dp[i,j,]:=<<;
end;
dp[,,]:=; //dp[,,]:=;
g[]:=;
for i:= to n- do
for j:= to m do
begin
dp[i+,j,]:=min(dp[i+,j,],dp[i,j,]+f[c[i],c[i+]]); if j+<=m then dp[i+,j+,]:=min(dp[i+,j+,],dp[i,j,]+g[i+]*f[c[i],d[i+]]
+(-g[i+])*f[c[i],c[i+]]); dp[i+,j,]:=min(dp[i+,j,],dp[i,j,]+g[i]*f[d[i],c[i+]]
+(-g[i])*f[c[i],c[i+]]); if j+<=m then dp[i+,j+,]:=min(dp[i+,j+,],dp[i,j,]+
g[i]*g[i+]*f[d[i],d[i+]]+
g[i]*(-g[i+])*f[d[i],c[i+]]+
(-g[i])*g[i+]*f[c[i],d[i+]]+
(-g[i])*(-g[i+])*f[c[i],c[i+]]); end;
ans:=<<;
for i:= to m do ans:=min(ans,min(dp[n,i,],dp[n,i,]));
writeln(ans::); end.
【NOIP2016】换教室(DP,期望)的更多相关文章
- bzoj 4720: [Noip2016]换教室【期望dp】
		
状压dp,设f[i][j][0/1]为前i个时间段换了j间教室的期望体力消耗,转移很好想(但是写起来好长= =) #include<iostream> #include<cstdio ...
 - P1850 换教室[dp+期望]
		
流下了不会概率的眼泪,由于不会概率,转移少写了点东西... 这个dp很简单,就是一个普通的线性dp加点期望.(刚开始写这道题时信笔写下) \(dp[0/1][i][j]\)表示到第\(i\)个时间段时 ...
 - Noip2016换教室(期望+DP)
		
Description 题目链接:Luogu Solution 这题结合了DP和概率与期望,其实只要稍微知道什么是期望就可以了, 状态的构造很关键,\(F[i][j][0/1]\)表示已经到第\(i\ ...
 - 2018.08.30 bzoj4720: [Noip2016]换教室(期望dp)
		
传送门 一道无脑的期望dp. 用f[i][j][0/1]表示前i堂课提出了j次申请且第i堂课没有(有)提出申请. 这样就可以状态转移了. 然而这题状态转移方程有点长... (主要是情况多... 代码: ...
 - [Noip2016]换教室(期望+DP)
		
Description 题目链接:Luogu Solution 这题结合了DP和概率与期望,其实只要稍微知道什么是期望就可以了, 状态的构造很关键,\(F[i][j][0/1]\)表示已经到第\(i\ ...
 - [NOIP2016]换教室 D1 T3 Floyed+期望DP
		
[NOIP2016]换教室 D1 T3 Description 对于刚上大学的牛牛来说, 他面临的第一个问题是如何根据实际情况中情合适的课程. 在可以选择的课程中,有2n节课程安排在n个时间段上.在第 ...
 - bzoj4720: [Noip2016]换教室(期望dp)
		
4720: [Noip2016]换教室 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1294 Solved: 698[Submit][Status ...
 - BZOJ 4720 [Noip2016]换教室
		
4720: [Noip2016]换教室 Description 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程.在可以选择的课程中,有2n节课程安排在n个时间段上.在第i( ...
 - 【BZOJ】4720: [Noip2016]换教室
		
4720: [Noip2016]换教室 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1690 Solved: 979[Submit][Status ...
 - [NOIP2016]换教室 题解(奇怪的三种状态)
		
2558. [NOIP2016]换教室 [题目描述] 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有2n节课程安排在n个时间段上.在第i(1< ...
 
随机推荐
- 数据类型-------JavaScript
			
之前只是简单的学过JavaScript和JQuery,虽然一般的要求都能完成,但并没有深入,这次是看了一个网站,很详细的教学,想重新认识一下JavaScript和JQuery. 本文摘要:http:/ ...
 - Java基础面试操作题:线程同步代码块 两个客户往一个银行存钱,每人存三十次一次存一百。 模拟银行存钱功能,时时银行现金数。
			
package com.swift; public class Bank_Customer_Test { public static void main(String[] args) { /* * 两 ...
 - C#与SQLServer数据库连接
			
第一种连接数据库方法:直接通过数据库的用户名.密码等连接 步骤: (1)建立SqlConnection对象,指定SqlConnection对象的ConnectionString属性: (2)打开数据库 ...
 - Element-ui tree组件自定义节点使用方法
			
工作上使用到element-ui tree 组件,主要功能是要实现节点拖拽和置顶,通过自定义内容方法(render-content)渲染树代码如下~ <template> <di ...
 - 在Linux系统中重现黑客帝国经典画面
			
我们需要一个叫cmatrix的小程序,下面写出步骤 1 :依赖环境 yum -y install gcc ncurses-devel 2 :下载程序 wget https://files.cnbl ...
 - 19.Yii2.0框架模型删除记录
			
目录 //删除记录 //http://yii.com/?r=home/del public function actionDel() { //查出要删除的记录行 // 方法一:(查一行,删一行) // ...
 - python文件打包为exe可执行文件的方法
			
我自己常用Pyinstaller库打包 第一步: 安装pyinstaller库 pip install pyinstaller 第二步: 在py文件所在目录输入 mydemo.py是自己写的py文 ...
 - ACM Changchun 2015    L . House Building
			
Have you ever played the video game Minecraft? This game has been one of the world's most popular ga ...
 - 用qemu+gdb tcp server+CDT调试linux内核启动-起步
			
用qemu+gdb tcp server+CDT调试linux内核启动-起步 说明: 环境信息与 用virtualbox+模拟串口+CDT调试linux内核 TCP IP协议栈-起步 提到的一样,并且 ...
 - 2017"百度之星"程序设计大赛 - 初赛(A)
			
小C的倍数问题 Accepts: 1990 Submissions: 4931 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 327 ...