线性dp-LIS题目6(友好城市,二分优化)

题目链接

1 解题过程

1.1 题意理解

这道题的突破口在"编程帮助政府做出一些批准和拒绝申请的决定,使得在保证任意两条航道不相交的情况下,被批准的申请尽量多。"

这里意味着我们要根据南岸和北岸数据去找最长不下降子序列。

1.2 解题思路

我们可以对这些城市用结构体存储其南岸和北岸的坐标。定义数组 d p dp dp, d p i dpi dpi表示前 i i i对城市最多获批的数量。先按南岸坐标从小到大排序,之后遍历排好序的城市,对于当前城市对 i i i,遍历其前面的程序如果前面有一对城市 j j j北岸坐标也比当前这对城市的北岸坐标小,那就执行状态转移方程 d p i = m a x ( d p i , d p j + 1 ) dpi=max(dpi,dpj+1) dpi=max(dpi,dpj+1)。

1.3 时间复杂度优化

这样做时间复杂度为O(n2),对于N达到2*105的规模是会超时的。我们可以用二分来优化。和前面一样,遍历每对城市,记 l e n n lenn lenn为最多获批的城市对数(初始化为0)。令 l = 0 , r = l e n n l=0,r=lenn l=0,r=lenn,这里可以理解为找北岸的最长不下降子序列。核心代码是:

cpp 复制代码
int l = 1, r = lenn;
		if (c[i].n >= b[lenn]) {
			++lenn;
			b[lenn] = c[i].n;
		}
		while (l <= r) {
			int mid = l + r >> 1;
			if (c[i].n >= b[mid])
				l = mid + 1;
			else
				r = mid - 1;
		}
		b[l] = c[i].n;

其中, c i . n ci.n ci.n记录第 i i i对城市的北岸坐标,b数组现有的子序列的城市北岸坐标,是不下降的。如果 c i . n > = b m i d ci.n>=bmid ci.n>=bmid,也就是当前的北岸坐标比序列的北岸坐标 b m i d bmid bmid大或坐标位置一样时,可能接在 m i d + 1 mid+1 mid+1或者更后面;否则,接在 m i d mid mid位置的前面,对于后面的城市对更好接。

2 AC Code

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
struct city {
	int n, s;
	friend bool operator<(city a, city b) {
		return a.s < b.s;
	}
} c[200005];
int cn, dp[200005], b[200005];
int main() {
	cin >> cn;
	for (int i = 1; i <= cn; i++) {
		dp[i] = 1;
		cin >> c[i].s >> c[i].n;
	}
	int lenn = 0;
	sort(c + 1, c + cn + 1);
	for (int i = 1; i <= cn; i++) {
		int l = 1, r = lenn;
		if (c[i].n >= b[lenn]) {
			++lenn;
			b[lenn] = c[i].n;
		}
		while (l <= r) {
			int mid = l + r >> 1;
			if (c[i].n >= b[mid])
				l = mid + 1;
			else
				r = mid - 1;
		}
		b[l] = c[i].n;
	}
	cout << lenn;
	return 0;
}
相关推荐
先吃饱再说20 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考2 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队2 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC3 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode