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

导弹防御系统(dfs+最长上升子序列)原题连接/为了对抗附近恶意国家的威胁,R 国更新了他们的导弹防御系统。一套防御系统的导弹拦截高度要么一直 严格单调 上升要么一直 严格单调 下降。例如,一套系统先后拦截了高度为 3 和高度为 4 的两发导弹,那么接下来该系统就只能拦截高度大于 4 的导弹。给定即将袭来的一系列导弹的高度,请你求出至少需要多少套防御系统,就可以将它们全部击落。输入格式输入包含多组测试用例。对于每个测试用例,第一行包含整数 n,表示来袭导弹数量。第二行包含 n 个不同的整数,表示每个导弹的高度。当输入测试用例

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

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

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

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

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

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

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

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

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

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

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

5
3 5 2 4 1
0 

输出样例:

2

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

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

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

#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.net/168756.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月8日 下午2:00
下一篇 2022年8月8日 下午2:00


相关推荐

  • 三角剖分算法

    三角剖分算法目录一 引言 1 背景 2 研究意义二 散乱点集剖分算法 1 Lawson 算法 2 Bowyer 算法 3 算法的优化 4 程序实现三 三角形剖分算法 1 实现思想 2 代码实现一 引言 1 背景本算法来源于美术馆问题 美术馆问题如下 假如有一个凹四边形的美术馆 我们需要在美术馆当中安排尽可能少的警卫 使得他们能观察到美术馆的所有角落 对于一个形状复杂的美术馆 如下图示 至少需要安排多少个警卫呢 这就是著名的美术馆问题 ArtGaller

    2026年3月17日
    2
  • Aggregate聚集的概念

    Aggregate聚集的概念<摘自网络>BW中聚集是指根据InfoCube中几个或者一个维度信息对象创建的小的CUBE,其实是新生成一张事实表,外加一些对应的维度表,可以提供数据的访问效率。Anaggregateisarollupoffactdatawhereatotalvalueissufficientandnodetailedinformationisneede…

    2022年5月20日
    42
  • python3.7如何安装numpy库_python升级后第三方库

    python3.7如何安装numpy库_python升级后第三方库1.这是个傻瓜教程,首先打开pycharm,点击左上脚的File,选择settings,找到project中的pythoninterpreter点击图中加号,即可添加库2.直接在输入框中输入要安装的库,点击安装即可

    2022年8月27日
    5
  • 全局低级键盘钩子[通俗易懂]

    全局低级键盘钩子[通俗易懂]/*========================================================================文件:kbevent.h说明:全局消息钩子时间:2005-03-20编写:oshj||oshj@21cn.c

    2022年5月8日
    35
  • 银河麒麟安装qt开发环境_优麒麟怎么样

    银河麒麟安装qt开发环境_优麒麟怎么样1.如果你对中标麒麟系统安装有疑问,请阅读上一篇文章:《中标麒麟/NeoKylinU盘安装系统》。2.进入系统打开终端,以root模式操作。&lt;1&gt;yuminstallgstream*libXext-devellibX11-devel&lt;2&gt;ln-s/usr/lib64/libXrender.so.1.3.0/usr/lib64/libXrend…

    2022年8月10日
    16
  • Python 正则表达式详解(建议收藏!)[通俗易懂]

    Python 正则表达式详解(建议收藏!)[通俗易懂]目录匹配字符串单字符匹配.匹配任意一个字符\d匹配单个数字\D匹配非数字的\s匹配特殊字符,如空白,空格,tab等\S匹配非空白\w匹配单词、字符,如大小写字母,数字,_下划线\W匹配非单词字符[]匹配[]中列举的字符正则表达式是对字符串提取的一套规则,我们把这个规则用正则里面的特定语法表达出来,去匹配满足这个规则的字符串。正则表达式具有通用型,不仅python里面可以用,其他的语言也一样适用。python中re模块提供了正则表达…

    2022年10月3日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号