前言
文章仅分享一下个人的思路和可以在我们学校网站全通过的代码,如果有更好的思路欢迎评论分享。本人目前还是个菜鸟,代码写的并不优美,有需要注意的地方还请提出来呀! q(≧▽≦q)
一、问题描述
【问题描述】
某国为了防御敌国的导弹袭击,开发出一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭,并观测到导弹依次飞来的高度,请计算这套系统最多能拦截多少导弹。拦截来袭导弹时,必须按来袭导弹袭击的时间顺序,不允许先拦截后面的导弹,再拦截前面的导弹。
【输入形式】
每组输入有两行,
第一行,输入雷达捕捉到的敌国导弹的数量k(k<=25),
第二行,输入k个正整数,表示k枚导弹的高度,按来袭导弹的袭击时间顺序给出,以空格分隔。
【输出形式】
每组输出只有一行,包含一个整数,表示最多能拦截多少枚导弹。
【样例输入】
8
300 207 155 300 299 170 158 65
【样例输出】
6
二、思路分析
1.如何存储导弹信息
由题目可知,发射的拦截导弹的高度满足后面的高度不超过前面的导弹的高度,不妨用结构体存储每个导弹的信息:
struct Missile
{
int Hight=0;
int Max=0;
};
其中Hight表示导弹的高度,Max表示到该导弹为止(包含该导弹)按高度排列的最大递减序列的长度,用这种方式存储每个导弹的信息,所有导弹中最大的Max即为所求
2.如何确定每个导弹的最大拦截数
首先将输入的第一颗导弹的高度所对应的Max设为1,对于后续输入的导弹,每次输入时将之前所有已确定信息的导弹遍历一遍,在之前的导弹中找到高度低于当前导弹的导弹,取其中Max的最大值,则Max+1即为到当前导弹为止的最大拦截数
三、代码
//302.导弹防御系统
/*
后面每一发的高度都不能高于前一发
求最多可以拦截导弹的数量 拦截按照导弹到来的顺序
*/
#include<bits/stdc++.h>
using namespace std;
struct Missile
{
int Hight=0;
int Max=0;
};
int main()
{
int n;
cin>>n;
Missile *mem=new Missile[n];
int tem;
for(int i=0;i<n;i++)
{
cin>>tem;
if(i==0)
{
mem[i].Hight=tem;
mem[i].Max=1;
}
else
{
mem[i].Hight=tem;
mem[i].Max=1;
for(int j=0;j<i;j++)
{
if(mem[j].Hight>=mem[i].Hight&&mem[j].Max>=mem[i].Max)
mem[i].Max=mem[j].Max+1;
}
}
}
int num=0;
for(int i=0;i<n;i++)
{
if(num<mem[i].Max)
num=mem[i].Max;
}
cout<<num;
delete []mem;
}
总结
由于本人不对本题的递归思想不是很了解 (+_+)?,通过运用结构体,每次输入新的导弹信息就立刻根据之前的导弹信息确定到该导弹为止最大拦截数,由于每次输入一个导弹的信息后都要与之前的所有导弹信息进行比较,故时间复杂度为O(n^2)