动态规划刷题(算法竞赛、蓝桥杯)--导弹拦截(线性DP)

1、题目链接:[NOIP1999 提高组] 导弹拦截 - 洛谷

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N=2e5+5;
int a[N],x,n;
int b[N],len;

int main(){
	while(cin>>x)a[++n]=x;
	//求最长不上升子序列 
	b[0]=2e9;//初始化为无穷大
	for(int i=1;i<=n;i++){
		if(a[i]<=b[len])b[++len]=a[i];//小则添加 
		else{
			int l=1,r=len;
			while(l<r){
				int mid=l+r>>1;
				if(a[i]>b[mid])r=mid;
				else l=mid+1;
			}
			b[l]=a[i]; 
		}
	}
	cout<<len<<endl;
	len=0;
	//求最长上升子序列
	b[0]=-2e9;
	for(int i=1;i<=n;i++){
		if(a[i]>b[len])b[++len]=a[i];
		else{
			int l=1,r=len;
			while(l<r){
				int mid=l+r>>1;
				if(b[mid]>=a[i])r=mid;
				else l=mid+1;
			}
			b[l]=a[i];
		} 
	} 
	cout<<len<<endl;
	
	return 0;
}
相关推荐
Amor风信子6 分钟前
华为OD机试真题---跳房子II
java·数据结构·算法
戊子仲秋23 分钟前
【LeetCode】每日一题 2024_10_2 准时到达的列车最小时速(二分答案)
算法·leetcode·职场和发展
邓校长的编程课堂25 分钟前
助力信息学奥赛-VisuAlgo:提升编程与算法学习的可视化工具
学习·算法
sp_fyf_202442 分钟前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-03
人工智能·算法·机器学习·计算机视觉·语言模型·自然语言处理
Eric.Lee20211 小时前
数据集-目标检测系列- 螃蟹 检测数据集 crab >> DataBall
python·深度学习·算法·目标检测·计算机视觉·数据集·螃蟹检测
林辞忧1 小时前
算法修炼之路之滑动窗口
算法
￴ㅤ￴￴ㅤ9527超级帅2 小时前
LeetCode hot100---二叉树专题(C++语言)
c++·算法·leetcode
liuyang-neu2 小时前
力扣 简单 110.平衡二叉树
java·算法·leetcode·深度优先
penguin_bark2 小时前
LCR 068. 搜索插入位置
算法·leetcode·职场和发展
_GR2 小时前
每日OJ题_牛客_牛牛冲钻五_模拟_C++_Java
java·数据结构·c++·算法·动态规划