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)个时间段上,两节内容相同的课程同时在不同的 ...
随机推荐
- 2019牛客多校第三场H Magic Line 思维
Magic Line 题意 给出n(偶)个整点 整点范围1000,找出一条直线,把n个点分成均等的两部分 分析 因为都是整数,并且范围比较小,所以直接按x排序找到在中间那一部分,并且把中间那一部分的点 ...
- python 中if和elif的区别
如果程序中判断事件很多,全部用if的话,会遍历整个程序,用elif 程序运行时,只要if或后续某一个elif之一满足逻辑值为True,则程序执行完对应输出语句后自动结束该轮if-elif(即不会再去冗 ...
- How To Use These LED Garden Lights
Are you considering the lighting options for the outdoor garden? Depending on how you use it, LED ga ...
- 劳动人民万岁(拒绝惰性)------- 浅谈迭代对象(Iterable) 迭代器(Iterator)
一.前戏 问题:如果一次抓取所有城市天气 再显示,显示第一个城市气温时有很高的延时,并且很浪费储存空间 解决方案:以“用时访问”策略,并且能把说有城市气温封装到一个对象里,可用for一句进行迭代 二. ...
- Linux中 /boot 目录介绍
转自https://blog.csdn.net/dulin201004/article/details/7396968 一./boot/目录中的文件和目录 Linux系统在本地启动时,目录/boot/ ...
- springboot中druid监控的配置(DruidConfiguration)
当数据库连接池使用druid 时,我们进行一些简单的配置就能查看到sql监控,web监控,url监控等等. 以springboot为例,配置如下 import com.alibaba.druid.su ...
- 利用mnist训练集生成的caffemodel对mnist测试集与自己手写的数字进行测试
从一到二:利用mnist训练集生成的caffemodel对mnist测试集与自己手写的数字进行测试 通过从零到一的教程,我们已经得到了通过mnist训练集生成的caffemodel,主要包含下面四个文 ...
- 题解【Codeforces1186A】 Vus the Cossack and a Contest
这题是入门难度的题目吧-- 根据题意可以得出,只有当\(m\)和\(k\)都大于等于\(n\)时,\(Vus\)才可以实现他的计划. 因此,我们不难得出以下\(AC\)代码: #include < ...
- 每天进步一点点------Verilog 测试平台(Testbench) (一)
每天进步一点点------Verilog 测试平台(Testbench) (一)
- Linux Ubuntu运行线程程序出现undefined reference to ‘pthread_create’和undefined reference to ‘pthread_join’错误。
Linux Ubuntu运行线程程序出现undefined reference to ‘pthread_create’和undefined reference to ‘pthread_join’错误. ...