NOIP2016换教室 BZOJ 4720
BZOJ 4720 换教室
题目描述:
Input
Output
Sample Input
2 1 2
1 2 1
0.8 0.2 0.5
1 2 5
1 3 3
2 3 1
Sample Output
dp[i][j][] = min(dp[i][j][],dp[i - ][j][] + dis[c[i - ]][c[i]]);
dp[i][j][] = min(dp[i][j][],dp[i - ][j][] + k[i - ] * dis[d[i - ]][c[i]] + ( - k[i - ]) * dis[c[i - ]][c[i]]);
dp[i][j][1]的转移就比较复杂了,分两种。
第一种,上一节课没有申请,那么转移只要从dp[i - 1][j - 1][0]转移过来就可以了,转移是只需要考虑这一次成不成功的期望
第二种,上一次也申请了,转移从dp[i - 1][j - 1][1]转移,但是估计期望距离的时候就比较麻烦了,上一次可以成功||不成功,这次也是,共有四种情况。
处理好细节~
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm> #define RI register int
using namespace std;
typedef long long ll; const int INF = 1e9 + ;
const int MAXN = + ; #define max(a,b) ((a) > (b) ? (a) : (b))
#define min(a,b) ((a) < (b) ? (a) : (b)) inline void read(int &x)
{
x = ;
bool flag = ;
char ch = getchar();
while(ch < '' || ch > '')
{
if(ch == '-') flag = ;
ch = getchar();
}
while(ch >= '' && ch <= '')
{
x = x * + ch - '';
ch = getchar();
}
if(flag) x *= -;
} int n,m,v,e;
double dp[MAXN][MAXN][],k[MAXN],ans;
int dis[MAXN][MAXN],c[MAXN],d[MAXN],f,t,val; void init()
{
memset(dp,,sizeof(dp));
memset(dis,0x3f,sizeof(dis));
ans = dp[][][],dp[][][] = ,dp[][][] = ;
} void get()
{
read(n),read(m),read(v),read(e);
for(int i = ;i <= v;i ++) dis[i][i] = ;
for(int i = ;i <= n;i ++) read(c[i]);
for(int i = ;i <= n;i ++) read(d[i]);
for(int i = ;i <= n;i ++) scanf("%lf",&k[i]);
for(int i = ;i <= e;i ++)
{
read(f),read(t),read(val);
if(f == t) continue;
dis[f][t] = dis[t][f] = min(val,dis[f][t]);
}
} void floyd()
{
for(RI k = ;k <= v;k ++)
for(RI i = ;i <= v;i ++)
for(RI j = ;j <= v;j ++)
dis[i][j] = min(dis[i][j],dis[i][k] + dis[k][j]);
} void DP()
{
for(RI i = ;i <= n;i ++)
{
dp[i][][] = dp[i - ][][] + dis[c[i - ]][c[i]];
for(RI j = ;j <= min(m,i);j ++)
{
dp[i][j][] = min(dp[i][j][],dp[i - ][j][] + dis[c[i - ]][c[i]]);
dp[i][j][] = min(dp[i][j][],dp[i - ][j][] + k[i - ] * dis[d[i - ]][c[i]] + ( - k[i - ]) * dis[c[i - ]][c[i]]);
dp[i][j][] = min(dp[i][j][],dp[i - ][j - ][] + k[i] * dis[c[i - ]][d[i]] + ( - k[i]) * dis[c[i - ]][c[i]]);
dp[i][j][] = min(dp[i][j][],dp[i - ][j - ][] +
k[i - ] * k[i] * dis[d[i - ]][d[i]] +
k[i - ] * ( - k[i]) * dis[d[i - ]][c[i]] +
( - k[i - ]) * k[i] * dis[c[i - ]][d[i]] +
( - k[i - ]) * ( - k[i]) * dis[c[i - ]][c[i]]);
if(i == n) ans = min(ans,dp[i][j][]),ans = min(ans,dp[i][j][]);
}
}
ans = min(ans,dp[n][][]);
printf("%.2lf\n",ans);
} int main()
{
init();
get();
floyd();
DP();
return ;
}
NOIP2016换教室 BZOJ 4720的更多相关文章
- 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 ...
- bzoj4720: [Noip2016]换教室(期望dp)
4720: [Noip2016]换教室 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1294 Solved: 698[Submit][Status ...
- [NOIP2016]换教室 D1 T3 Floyed+期望DP
[NOIP2016]换教室 D1 T3 Description 对于刚上大学的牛牛来说, 他面临的第一个问题是如何根据实际情况中情合适的课程. 在可以选择的课程中,有2n节课程安排在n个时间段上.在第 ...
- [NOIP2016]换教室 题解(奇怪的三种状态)
2558. [NOIP2016]换教室 [题目描述] 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有2n节课程安排在n个时间段上.在第i(1< ...
- 【bzoj4720】[NOIP2016]换教室
题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程.在可以选择的课程中,有2n节课程安排在n个时间段上.在第i(1≤i≤n)个时间段上,两节内容相同的课程同时在不同的 ...
- [NOIp2016] 换教室
题目类型:期望\(DP\) 传送门:>Here< 题意:现有\(N\)个时间段,每个时间段上一节课.如果不申请换教室,那么时间段\(i\)必须去教室\(c[i]\)上课,如果申请换课成功, ...
- [NOIP2016]换教室(概率期望$DP$)
其实吧我老早就把这题切了--因为说实话,这道题确实不难啊--李云龙:比他娘的状压DP简单多了 今天我翻以前在Luogu上写的题解时,突然发现放错代码了,然后被一堆人\(hack\)--蓝瘦啊\(ORZ ...
- 【bzoj4720】[NOIP2016]换教室 期望dp
题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程.在可以选择的课程中,有2n节课程安排在n个时间段上.在第i(1≤i≤n)个时间段上,两节内容相同的课程同时在不同的 ...
随机推荐
- 【C语言】用C语言输出“心形”图案
在你们的世界里,是不是觉得程序猿一点浪漫都不懂?其实不是的,程序猿的世界也是很浪漫滴! 傻瓜版 int main() { printf("❤"); ; } 高级版 //版本一:单个 ...
- linux 系统如何复制文件到指定目录
首先使用命令函数“cp” 即copy的缩写, 一般模式: cp filename 路径. 如file1在A目录下,我们想把file1复制到B目录下 命令为 cp file1 /home/B ...
- 【转载】C/C++内存管理详解
转自:http://chenqx.github.io/2014/09/25/Cpp-Memory-Management/ 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题,C++高手从中 ...
- 【转载】SpringMVC框架介绍
转自:http://com-xpp.iteye.com/blog/1604183 SpringMVC框架图 SpringMVC接口解释 DispatcherServlet接口: Spring提 ...
- 如何预测股票分析--长短期记忆网络(LSTM)
在上一篇中,我们回顾了先知的方法,但是在这个案例中表现也不是特别突出,今天介绍的是著名的l s t m算法,在时间序列中解决了传统r n n算法梯度消失问题的的它这一次还会有令人杰出的表现吗? 长短期 ...
- C语言程序设计100例之(28):直线蛇形阵
例28 直线蛇形阵 问题描述 编写程序,将自然数1.2.….N2按蛇形方式逐个顺序存入N阶方阵.例如,当N=3和N=4时的直线蛇形阵如下图1所示. 图1 直线蛇形阵 输入格式 一个正整 ...
- IntelliJ IDEA 2017.3尚硅谷-----界面展示
- opencv:图像去噪(椒盐噪声)
#include <opencv2/opencv.hpp> #include <iostream> using namespace cv; using namespace st ...
- Ubuntu16.04 anaconda3 opencv3.1.0 安装CPU版本caffe
安装anaconda3 安装opencv3.1.0 安装依赖库 修改Makefile.config 修改Makefile 编译报错,卸载anaconda中的protobuffer: conda uni ...
- java 实体类 时间格式字段注解
@DatetimeFormat是将String转换成Date,一般前台给后台传值时用 @JsonFormat(pattern="yyyy-MM-dd") 将Date转换成Strin ...