前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >导弹防御系统(dfs+最长上升子序列)

导弹防御系统(dfs+最长上升子序列)

作者头像
全栈程序员站长
发布2022-09-22 09:49:16
1830
发布2022-09-22 09:49:16
举报
文章被收录于专栏:全栈程序员必看

/为了对抗附近恶意国家的威胁,R 国更新了他们的导弹防御系统。

一套防御系统的导弹拦截高度要么一直 严格单调 上升要么一直 严格单调 下降。

例如,一套系统先后拦截了高度为 3 和高度为 4 的两发导弹,那么接下来该系统就只能拦截高度大于 4 的导弹。

给定即将袭来的一系列导弹的高度,请你求出至少需要多少套防御系统,就可以将它们全部击落。

输入格式 输入包含多组测试用例。

对于每个测试用例,第一行包含整数 n,表示来袭导弹数量。

第二行包含 n 个不同的整数,表示每个导弹的高度。

当输入测试用例 n=0 时,表示输入终止,且该用例无需处理。

输出格式 对于每个测试用例,输出一个占据一行的整数,表示所需的防御系统数量。

数据范围 1≤n≤50 输入样例:

代码语言:javascript
复制
5
3 5 2 4 1
0 

输出样例:

代码语言:javascript
复制
2

样例解释 对于给出样例,最少需要两套防御系统。

一套击落高度为 3,4 的导弹,另一套击落高度为 5,2,1 的导弹。

题解 dfs+最长上升序列,对每个数有两个选择,一个是选择向上一个选择向下

代码语言:javascript
复制
#include<bits/stdc++.h>
#include<cmath>
#define x first
#define y second
#define send string::npos
#define lowbit(x) (x&(-x))
#define left(x) x<<1
#define right(x) x<<1|1
using namespace std;
typedef long long ll;
typedef pair<int,int> PII;
typedef struct Node * pnode;
const int N = 1e3 + 10;
const int M = 5e5 + 10;
const int INF = 0x3f3f3f3f;
const ll LINF = 0x3f3f3f3f3f3f3f3f;
const int Mod = 4e8;
int up[N],down[N],a[N];
int cnt_up,cnt_down;
int n,res = INF;
void dfs(int u){ 
   
    if(cnt_down + cnt_up >= res)return;
    if(u == n){ 
   
        res = cnt_up + cnt_down;
        return;
    }
    int k = 0,Max;
    while(k < cnt_up && up[k] <= a[u])k ++;
    if(k == cnt_up){ 
   
        up[cnt_up ++] = a[u];
        dfs(u + 1);
        cnt_up --;
    }
    else { 
   
        int t = up[k];
        up[k] = a[u];
        dfs(u + 1);
        up[k] = t;
    }
    k = 0;
    while(k < cnt_down && down[k] >= a[u])k ++;
    if(k == cnt_down){ 
   
        down[cnt_down ++] = a[u];
        dfs(u + 1);
        cnt_down --;
    }else{ 
   
        int t = down[k];
        down[k] = a[u];
        dfs(u + 1);
        down[k] = t;
    }

}
int main(){ 
   
    while(cin>>n && n){ 
   
        memset(up,0,sizeof up);
        memset(down,0,sizeof down);
        cnt_up = cnt_down = 0;
        res = INF;
        for(int i = 0;i < n;i ++)cin>>a[i];
        dfs(0);
        cout<<res<<endl;
    }
    return 0;
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/168756.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档