noi.ac #289. 电梯(单调队列)
题意
Sol
傻叉的我以为给出的\(t\)是单调递增的,然后\(100\rightarrow0\)
首先可以按\(t\)排序,那么转移方程为
\(f[i] = min_{j=0}^{i-1}(max(t[i], f[j]) + 2 * max_{k=j+1}^i x[k])\)
不难发现,若\(i < j\)且\(x[i] < x[j]\),那么从\(i\)转移过来一定是不优的,一定是从\(i\)之前的某个位置转移过来。(f单增)
然后直接单调队列搞一搞就行了,
#include<bits/stdc++.h>
#define Pair pair<int, int>
#define fi first
#define se second
#define LL long long
#define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 1<<22, stdin), p1 == p2) ? EOF : *p1++)
char buf[(1 << 22)], *p1 = buf, *p2 = buf;
using namespace std;
const int MAXN = 1e6 + 10;
template <typename A, typename B> inline bool chmin(A &a, B b){if(a > b) {a = b; return 1;} return 0;}
template <typename A, typename B> inline bool chmax(A &a, B b){if(a < b) {a = b; return 1;} return 0;}
inline int read() {
    char c = getchar(); int x = 0, f = 1;
    while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
    while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
    return x * f;
}
int N, q[MAXN], val[MAXN], top;
LL f[MAXN];
Pair a[MAXN];
signed main() {
	N = read();
	for(int i = 1; i <= N; i++) a[i].fi = read(), a[i].se = read();
	sort(a + 1, a + N + 1);
	for(int i = 1; i <= N; i++) {
		while(top && a[i].se > a[top].se) top--;
		a[++top] = a[i];
	}
	memset(f, 0x7f, sizeof(f));
	N = top; f[0] = 0;
	int l = 1, r = 0, las = 0;
	for(int i = 1; i <= N; i++) {
		while(l <= r && a[i].fi >= f[q[l]]) las = q[l++];
		if(las < i) chmin(f[i], a[i].fi + 2ll * a[las + 1].se);
		if(l <= r) chmin(f[i], val[l]);
		int cur = f[i] + 2ll * a[i + 1].se;
		while(l <= r && cur <= val[r]) r--;
		q[++r] = i; val[r] = cur;
	}
	cout << f[N];
    return 0;
}
noi.ac #289. 电梯(单调队列)的更多相关文章
- POJ 2823 Sliding Window (线段树/单调队列)
		题目不说了,可以用线段树或者单调队列,下面附上代码. 线段树: #include <iostream> #include <stdio.h> #include <algo ... 
- [NOIP2010初赛]烽火传递+单调队列详细整理
		P1313 [NOIP2010初赛]烽火传递 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 烽火台又称烽燧,是重要的防御设施,一般建在险要处或交通要道上 ... 
- DP+单调队列 codevs 1748 瑰丽华尔兹(还不是很懂具体的代码实现)
		codevs 1748 瑰丽华尔兹 2005年NOI全国竞赛 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题解 题目描述 Descripti ... 
- 【POJ 3162】 Walking Race (树形DP-求树上最长路径问题,+单调队列)
		Walking Race Description flymouse's sister wc is very capable at sports and her favorite event is ... 
- 使用单调队列优化的 O(nm) 多重背包算法
		我搜索了一下,找到了一篇很好的博客,讲的挺详细:链接. 解析 多重背包的最原始的状态转移方程: 令 c[i] = min(num[i], j / v[i]) f[i][j] = max(f[i-1][ ... 
- HDU 4122 Alice's mooncake shop (单调队列/线段树)
		传送门:http://acm.hdu.edu.cn/showproblem.php?pid=4122 题意:好难读懂,读懂了也好难描述,亲们就自己凑合看看题意把 题解:开始计算每个日期到2000/1/ ... 
- 【POJ 2823 Sliding Window】 单调队列
		题目大意:给n个数,一个长度为k(k<n)的闭区间从0滑动到n,求滑动中区间的最大值序列和最小值序列. 最大值和最小值是类似的,在此以最大值为例分析. 数据结构要求:能保存最多k个元素,快速取得 ... 
- POJ2823 Sliding Window(单调队列)
		单调队列,我用deque维护.这道题不难写,我第二次写单调队列,1次AC. -------------------------------------------------------------- ... 
- BZOJ 1012: [JSOI2008]最大数maxnumber【线段树单点更新求最值,单调队列,多解】
		1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 10374 Solved: 4535[Subm ... 
随机推荐
- Mysql索引最左匹配原则
			先来看个例子: 1. 示例1:假设有如下的一张表: DROP TABLE IF EXISTS testTable; CREATE TABLE testTable ( ID BIGINT NOT NUL ... 
- [Swift]LeetCode221. 最大正方形 | Maximal Square
			Given a 2D binary matrix filled with 0's and 1's, find the largest square containing only 1's and re ... 
- [Swift]LeetCode242. 有效的字母异位词 | Valid Anagram
			Given two strings s and t , write a function to determine if t is an anagram of s. Example 1: Input: ... 
- [Swift]LeetCode796. 旋转字符串 | Rotate String
			We are given two strings, A and B. A shift on A consists of taking string A and moving the leftmost ... 
- 《关于长沙.NET技术社区未来发展规划》问卷调查结果公布
			那些开发者们对于社区的美好期待 2月,长沙.net 技术社区自从把群拉起来开始,做了一次比较正式.题目为<关于长沙.NET技术社区未来发展规划>的问卷调查,在问卷调查中,溪源写道: 随着互 ... 
- mysql tablespace(独立表空间)超速备份大数据
			前序 对于用户自主创建的表,会采用此种模式,每个表由一个独立的表空间进行管理备份(速度相当的猛) 首先介绍一下文件 .ibd就被称之为独立表空间的数据文件 .frm就是元数据文件 就是创建表后生成的 ... 
- js的预解析
			在ES6之前,变量使用var声明,会存在变量的预解析(函数也有预解析).ES6引了let和const,但是现阶段ES6并没有完全普及,而且很多比较老的代码都还是按照ES5的标准甚至是ES3的标准来书写 ... 
- python传入不确定个数参数
			Python3自带的一个函数为 zip ,使用方式如下: In: print zip([1, 2],[3, 4]) Out: [(1, 3), (2, 4)] In: print zip([1, 2] ... 
- C#计算一段代码的运行时间
			第一种方法利用System.DateTime.Now: static void SubTest() { DateTime beforDT = System.DateTime.Now; //耗时巨大的代 ... 
- DDD实战进阶第一波(十五):开发一般业务的大健康行业直销系统(总结篇)
			前面我们花了14篇的文章来给大家介绍经典DDD的概念.架构和实践.这篇文章我们来做一个完整的总结,另外生成一个Api接口文档. 一.DDD解决传统的开发的几大问题: 没有描述需求的设计模型:而是直接通 ... 
