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#项目调用Python模块的方法
将Python模块用pyinstaller打包成exe程序 下载安装UPX((http://upx.sourceforge.net/)) ,并把路径加到环境变量中. UPX是开源的加壳和压缩exe的程 ...
- python 常用包之xml文件处理
1,处理xml的包 from xml.etree import ElementTree as ET 2,如何写出xml文件 xml文件和html中的元素很像,有父级子集之说, root = ET.El ...
- arcgis中的Join(合并连接)和Relate(关联连接)
arcgis中的Join(合并连接)和Relate(关联连接) 一.区别 1.连接关系不一样. Relate(关联连接)方式连接的两个表之间的记录可以是“一对一”.“多对一”.“一对多”的关系 Joi ...
- 计算几何-Line-Left-Intersect
This article is made by Jason-Cow.Welcome to reprint.But please post the article's address. 好好领悟一下ve ...
- nginx配置指令auth_basic、auth_basic_user_file及相关知识
参考链接 https://www.jianshu.com/p/1c0691c9ad3c auth_basic_user_file 所需要的密码,可以通过如下方法生成 1)安装htpasswd (yum ...
- 数据库备份与还原:mysqldump,source
*数据库备份* 1.备份方法一:适用于myslam表: 直接将tb_name.frm.tb_name.myd.tb_name.myi三个文件保存,备份即可. 需要的时候直接解压到,移动到相应的数据库目 ...
- 【做题笔记】P6014 [CSGRound3]斗牛
仔细读题:另外两张牌和的个位数即为你所获得的点数.对于Subtask 1,枚举即可.50 分. 考虑:取 \(n-2\) 张牌和取答案的 \(2\) 张牌本质是一样的.因为若取符合条件的 \(n-2\ ...
- ssm框架整合,配置文件中的配置内容
转自:https://www.cnblogs.com/dong-dong-1/p/8724127.html 使用idea工具开发,用maven进行管理. 最近在写毕业设计,因为对ssm框架一直半解,常 ...
- web项目获取路径
Java获取路径的各种方法: (1).request.getRealPath("/"); //不推荐使用获取工程的根路径 (2).request.getRealPath(requ ...
- linux 磁盘100% 清理
df -h 查看磁盘使用有一个vdb满了 df -i 查看inode 使用率 显示文件大小: du -sh /* du参数: -a : 列出所有的文件与目录容量,因为默认仅统计目录下面的文件量而 ...