• 最少拦截系统


    最少拦截系统

    Time Limit: 1000 ms Memory Limit: 65536 KiB

    Problem Description

     某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
    怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.
     
     

    Input

     输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)

    Output

     对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.
     

    Sample Input

    8 389 207 155 300 299 170 158 65

    Sample Output

    2

    Hint

    Source

     
     1 #include<bits/stdc++.h>
     2 using namespace std;
     3 int main()
     4 {
     5     int n,num;
     6     vector<int> data;
     7     while(cin>>n){
     8         data.clear();
     9         for(int i=0;i<n;i++){
    10             cin>>num;
    11             data.push_back(num);
    12         }
    13         int sum=0;
    14         for(int i=0;i<(int)data.size();i++){
    15             int height=data[i];//当前高度. (理解错题目了,汗)正确的:只要后面的 炮弹高度 比height 低,那么都可以打到
    16             for(int j=i+1;j<(int)data.size();j++){//需要全部找 一遍,把能拦截的 都删除掉
    17                 if(height>=data[j]){//更新高度
    18                     height=data[j];
    19                     data.erase(data.begin()+j);//删除 这个 能被拦截的高度
    20                     j--;//同时下标恢复位原来的
    21                 }
    22             }
    23             sum++;//需要的个数
    24         }
    25         cout<<sum<<endl;
    26     }
    27     return 0;
    28 }
  • 相关阅读:
    python学习day02
    鼓起勇气 大胆说不
    spring系列---- spring-mvc1
    win7-64位 jdk安装
    项目分层以及阶段期限规划
    老油条之记
    论软件与管理的关系---企业管理软件的末路
    软件项目管理之觞
    世界在变化-----谷歌不安全
    LPR利率与固定利率哪个更合算?
  • 原文地址:https://www.cnblogs.com/NirobertEinteson/p/11924093.html
Copyright © 2020-2023  润新知