【BZOJ4244】邮戳拉力赛 DP
【BZOJ4244】邮戳拉力赛
Description
Input
Output
Sample Input
1 1 1 1
1 9 9 1
9 9 1 1
1 9 9 1
Sample Output
HINT
题解:首先如果我们从左往右和从右往左都经过了这个车站,那么在这个车站左进右出和右进左出是都可以的。所以我们只考虑左进左出和右进右出的情况。我们将右进右出看成左括号,左进左出看成右括号,那么我们在绕路上花费的时间就是:2*(每对匹配的括号之间的距离之和),并且显然最终的结果是一个匹配的括号序列。所以令f[i][j]表示前i个车站,左边还有j个未匹配的左括号,的最小花费。转移比较容易。
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
int n,T;
int l0[3010],l1[3010],r0[3010],r1[3010],f[3010][3010];int main()
{scanf("%d%d",&n,&T);int i,j;memset(f,0x3f,sizeof(f));for(i=1;i<=n;i++) scanf("%d%d%d%d",&l0[i],&r1[i],&r0[i],&l1[i]);f[0][0]=0;for(i=1;i<=n;i++){for(j=0;j<=n;j++){if(j){f[i][j]=min(f[i][j],f[i-1][j-1]+(j-1)*2*T+r0[i]+r1[i]);f[i][j]=min(f[i][j],f[i-1][j]+j*2*T+r0[i]+l1[i]);}f[i][j]=min(f[i][j],f[i-1][j]+j*2*T+l0[i]+r1[i]);f[i][j]=min(f[i][j],f[i-1][j+1]+(j+1)*2*T+l0[i]+l1[i]);}for(j=1;j<=n;j++) f[i][j]=min(f[i][j],f[i][j-1]+r0[i]+r1[i]);for(j=n-1;j>=0;j--) f[i][j]=min(f[i][j],f[i][j+1]+l0[i]+l1[i]);}printf("%d",f[n][0]+(n+1)*T);return 0;
}
转载于:https://www.cnblogs.com/CQzhangyu/p/7787845.html
【BZOJ4244】邮戳拉力赛 DP相关推荐
- bzoj4244: 邮戳拉力赛 dp
Description IOI铁路是由N+2个站点构成的直线线路.这条线路的车站从某一端的车站开始顺次标号为0...N+1. 这条路线上行驶的电车分为上行电车和下行电车两种,上行电车沿编号增大方向行驶 ...
- BZOJ4244 邮戳拉力赛 dp
题目链接 题意: 题解: cwbc讲课因为时间原因没讲到的一道题,结果正睿rxd的模拟赛 感觉还是很神仙的,我感觉我好像不太能想出来这个题啊. 一道神仙dp题.我们发现,最后答案一定需要从0到n+1, ...
- [BZOJ4244]邮戳拉力赛
Description IOI铁路是由N+2个站点构成的直线线路.这条线路的车站从某一端的车站开始顺次标号为0...N+1. 这条路线上行驶的电车分为上行电车和下行电车两种,上行电车沿编号增大方向行驶 ...
- BZOJ 4244 邮戳拉力赛 (DP)
手动博客搬家: 本文发表于20181211 18:01:21, 原地址https://blog.csdn.net/suncongbo/article/details/84957907 为了防止我的博客 ...
- java越野拉力赛_BZOJ 4244 邮戳拉力赛 (DP)
为了防止我的博客被数学占领(一半以上的博文和数学相关),我决定添加几道非数学题的题解. 目前数学题比例: \(\frac{15}{32}=0.46875\) 扯淡结束 题意: 太长了自己看. 题解: ...
- [BZOJ 4244] 邮戳拉力赛
BZOJ传送门 Description IOI铁路是由N+2N+2N+2个站点构成的直线线路.这条线路的车站从某一端的车站开始顺次标号为0...N+10...N+10...N+1. 这条路线上行驶的电 ...
- bzoj4244 loj2878. 「JOISC 2014 Day2」邮戳拉力赛 括号序列+背包
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4244 https://loj.ac/problem/2878 题解 挺妙的一道题. 一开始一直 ...
- JOISC 2014 邮戳拉力赛(基础DP)
题意 https://loj.ac/problem/2878 思路 真的神仙题,想到就很好写,想不到就写不出来. 肯定只能一个一个邮戳按顺序分析.首先,将取一枚邮戳的路径分为四种: 上行 \(\rig ...
- [DP] BZOJ 4244 邮戳拉力赛
DP方程有点难懂 晕 #include<cstdio> #include<cstdlib> #include<cstring> #include<algori ...
最新文章
- 【Qt】Qt再学习(五):HTTP Example(HTTP下载文件的示例)
- 我所理解的Java NIO
- HTTP协议 (二) 基本认证
- Yocto tips (17): Yocto License问题:restricted license not whitelisted in LICENSE_FLAGS_WHITELIST
- Helix Streaming Server 简单配置
- ...三个点es6用法
- React高阶组件学习总结
- Windows网络编程之send()函数
- StringUtil.isNotEmpty
- Caused by: java.lang.IllegalArgumentException: Not a managed type: class com.xxxx.xxx
- AVM 拖动组件 movable-view 介绍
- 哔哩哔哩mac客户端!亲测!支持big sur系统
- 使用stty修改终端设置 stty 用法!
- 前沿 | 国际可视化盛会PacificVis2017的十个精彩案例
- 操作系统的了解和安装
- 【Windows】win10或win11的资源管理器 文件夹中存在今天、昨天、本周更早时候之类的分割线分组依据如何怎么去除去掉?
- joan sola_Joan Touzet在CouchDB和Apache方式上
- 《诚信》——赤兔之死
- 体验TiDB V6.0.0 之Clinic
- Chrome浏览器如何关闭自动更新
热门文章
- Python 模块 UUID 学习使用
- 加盐哈希-Salted Password Hashing
- 不要炒股 如何理财?
- 学堂在线网课自动观看
- excel自定义格式根据输入的数值显示整数和小数
- 指尖江湖鸿蒙抽奖,剑网3指尖江湖鸿蒙始清怎么玩 冬寒遗冰青鹤翎速刷攻略
- ansible命令行常用模块
- 刷机必看recovery和fastboot是什么意思
- Python学习:问题 VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a
- msa.h:没有那个文件或目录