【bzoj4244】邮戳拉力赛 背包dp
题目描述
输入
输出
样例输入
4 1
1 1 1 1
1 9 9 1
9 9 1 1
1 9 9 1
样例输出
23
题解
只可意会不可言传的非常神的背包dp,非常难写题解因此写的不好不要怪我。。。
考虑一个车站是怎么经过的,共有以下四种情况:
从后面来、往后面走,代价为d+v;
从前面来、往前面走,代价为u+e;
从后面来、往前面走,代价为d+e;
从前面来、往后面走,代价为u+v。
那么先不考虑从0直接到n+1的必经行程,中间的部分一定是一个回路。
从左向右考虑回路的每一段,必然是若干个向右的路线。把向右的路线看作左括号,向左的看作右括号,那么有:
第1种情况为'((',第2种情况为'))',第3种情况为')(',第4种情况为'()'。答案就是合法的括号序列。
设 $f[i][j]$ 表示前 $i$ 个位置,多余的'('数目为 $2j$ 的最小代价。那么考虑这4种情况即可。注意第3、4种情况可能出现多次,因此是完全背包。
转移之间需要加上回路的代价 $T·2j$ 。
最后加上从0到n+1的代价 $(n+1)T$ 即为答案。
时间复杂度 $O(n^2)$
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int f[3010][3010];
int main()
{
int n , m , i , j , u , v , d , e;
scanf("%d%d" , &n , &m);
memset(f , 0x3f , sizeof(f)) , f[0][0] = 0;
for(i = 1 ; i <= n ; i ++ )
{
scanf("%d%d%d%d" , &u , &v , &d , &e);
for(j = 1 ; j <= n ; j ++ ) f[i - 1][j] += j * m * 2;
for(j = 1 ; j <= n ; j ++ ) f[i][j] = min(f[i][j] , f[i - 1][j - 1] + d + v);
for(j = 0 ; j < n ; j ++ ) f[i][j] = min(f[i][j] , f[i - 1][j + 1] + u + e);
for(j = 1 ; j <= n ; j ++ ) f[i][j] = min(f[i][j] , f[i - 1][j] + d + e);
for(j = 0 ; j <= n ; j ++ ) f[i][j] = min(f[i][j] , f[i - 1][j] + u + v);
for(j = 1 ; j <= n ; j ++ ) f[i][j] = min(f[i][j] , f[i][j - 1] + d + v);
for(j = n - 1 ; ~j ; j -- ) f[i][j] = min(f[i][j] , f[i][j + 1] + u + e);
}
printf("%d\n" , f[n][0] + (n + 1) * m);
return 0;
}
【bzoj4244】邮戳拉力赛 背包dp的更多相关文章
- [BZOJ4244]邮戳拉力赛
Description IOI铁路是由N+2个站点构成的直线线路.这条线路的车站从某一端的车站开始顺次标号为0...N+1. 这条路线上行驶的电车分为上行电车和下行电车两种,上行电车沿编号增大方向行驶 ...
- 【BZOJ4244】邮戳拉力赛 DP
[BZOJ4244]邮戳拉力赛 Description IOI铁路是由N+2个站点构成的直线线路.这条线路的车站从某一端的车站开始顺次标号为0...N+1. 这条路线上行驶的电车分为上行电车和下行电车 ...
- 背包dp整理
01背包 动态规划是一种高效的算法.在数学和计算机科学中,是一种将复杂问题的分成多个简单的小问题思想 ---- 分而治之.因此我们使用动态规划的时候,原问题必须是重叠的子问题.运用动态规划设计的算法比 ...
- hdu 5534 Partial Tree 背包DP
Partial Tree Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid= ...
- HDU 5501 The Highest Mark 背包dp
The Highest Mark Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?p ...
- Codeforces Codeforces Round #319 (Div. 2) B. Modulo Sum 背包dp
B. Modulo Sum Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/577/problem/ ...
- noj [1479] How many (01背包||DP||DFS)
http://ac.nbutoj.com/Problem/view.xhtml?id=1479 [1479] How many 时间限制: 1000 ms 内存限制: 65535 K 问题描述 The ...
- HDU 1011 树形背包(DP) Starship Troopers
题目链接: HDU 1011 树形背包(DP) Starship Troopers 题意: 地图中有一些房间, 每个房间有一定的bugs和得到brains的可能性值, 一个人带领m支军队从入口(房 ...
- BZOJ 1004: [HNOI2008]Cards( 置换群 + burnside引理 + 背包dp + 乘法逆元 )
题意保证了是一个置换群. 根据burnside引理, 答案为Σc(f) / (M+1). c(f)表示置换f的不动点数, 而题目限制了颜色的数量, 所以还得满足题目, 用背包dp来计算.dp(x,i, ...
随机推荐
- 面试:sql语句-1-基础查询
1.基础查询
- .net mvc 使用ueditor的开发(官网没有net版本?)
1.ueditor的下载导入 官网下载地址:https://ueditor.baidu.com/website/download.html · 介绍 有两种,一种开发版,一种Mini版,分别长这样: ...
- 初探C#
初探.NET底层原理 学习C#离不开.net平台,因为微软的开发平台真的是太强大了,它为每一个开发者都做了太多太多,但是我们不仅要知道怎么用,而且也应该知道其中的内部到底包含了什么.本篇文章不仅讲一些 ...
- 第四篇 Postman之Pre-request Script(前置处理器:JS之 YYYY-MM-DD HH:MM:SS)
本篇来讲讲Pre-request Script 前置处理器,定义在发送request之前需要运行的一些脚本,应用场景主要是设置全局变量和环境变量. 本例子也是项目中遇到的,需要修改与客户的预约时间,但 ...
- Linux 安装Zookeeper<准备>(使用Mac远程访问)
阅读本文需要安装JDK 一 Zookeeper简介 zookeeper是用java语言编写的一款为分布式应用所设计的协调服务 zookeeper是apacahe hadoop的子项目 使用zookee ...
- TPO-16 C2 Reschedule the medieval history test
TPO-16 C2 Reschedule the medieval history test 第 1 段 1.Listen to a conversation between a Professor ...
- Python学习之web框架 Flask
一.通过PIP 安装Flask 1.1 Windows环境安装pip A.首先PIP进入官网(https://pypi.python.org/pypi/pip)下载gz包 B.对gz压缩包进行解压,解 ...
- Python基础知识-05-数据类型总结字典
python其他知识目录 1.一道题,选择商品的序号.程序员和用户各自面对的序号起始值 如有变量 googs = ['汽车','飞机','火箭'] 提示用户可供选择的商品: 0,汽车1,飞机2,火箭用 ...
- 关于《数据结构》课本KMP算法的理解
数据结构课上讲的KMP算法和我在ACM中学习的KMP算法是有区别的,这里我对课本上的KMP算法给出我的一些想法. 原理和之前的KMP是一样的https://www.cnblogs.com/wkfvaw ...
- 实验一 MiniOS
实验一.命令解释程序的编写实验 商软1班 杨晶晶 201406114102 一. 实验目的 (1)掌握命令解释程序的原理: (2)掌握简单的DOS调用方法: (3)掌握C语言编程初 ...