当前位置: 首页 > news >正文

dp-拦截导弹2

所有代码均来自于acwing中的算法基础课和算法提高课
Description

某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,
但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭。由于该系统还在试用阶段,所以只有一套系统,因此
有可能不能拦截所有的导弹。

Input

第一行输入M表示包含M组测试数据,每组第一个输入N (N<100)表示后面有N个整数,表示导弹依次飞来的高度(雷达给出的高度数据是
不大于30000的正整数)。

Output

对于每组输入数据,第一行输出这套系统最多能拦截多少导弹,以及输出如果要拦截所有导弹最少要配备多少套这种导弹拦截系统。

Sample Input

2
7 300 250 275 252 200 138 245
7 181 205 471 782 1033 1058 1111

Sample Output

5 2
1 7

#include "iostream"
#include "cstring"using namespace std;
const int N = 110;
int a[N];
int g[N];  // 第i套系统末尾元素
int f[N];  // 以第i个元素结尾的最长非下降子序列的数量
int length;  // 目前需要的系统的数量int main() {int M;cin >> M;while (M--) {int n;cin >> n;for (int i = 1; i <= n; ++i) {cin >> a[i];}// 求最长非下降子序列的数量for (int i = 1; i <=n ; ++i) {f[i]=1;for (int j = 1; j <i ; ++j) {if(a[i]<=a[j]){f[i] = max(f[i],f[j]+1);}}}int result = f[1];for (int i = 2; i <=n ; ++i) {result = max(result,f[i]);}cout << result<<" ";// 求所需要的系统的数量length = 1;for (int i = 1; i <= n; ++i) {int l = 1, r = length;while (l < r) {int mid = (l + r + 1) >> 1;if (a[i] <= g[mid]) {r = mid -1;} else {l = mid;}}g[r + 1] = a[i];length = max(length, r + 1);}cout << length-1 << endl;}
}
http://www.lryc.cn/news/252499.html

相关文章:

  • 初识动态规划算法(题目加解析)
  • Vue2.0与Vue3.0的区别
  • 探索人工智能领域——每日20个名词详解【day6】
  • C++初阶 | [七] string类(上)
  • Django总结
  • 【qml入门系列教程】:qml QtObject用法介绍
  • 2分图匹配算法
  • [EndNote学习笔记] 导出库中文献的作者、标题、年份到Excel
  • SQL Sever 基础知识 - 数据查询
  • Vue入门——v-on标签
  • JVM:双亲委派(未完结)
  • Leetcode 2661. 找出叠涂元素
  • vscode代码调试配置
  • PTA 7-225 sdut-C语言实验- 冒泡排序中数据交换的次数
  • 新的 BLUFFS 攻击导致蓝牙连接不再私密
  • 安全测试之推荐工具(一)
  • final关键字
  • WPF MVVM模式下如何将UI窗口变量传参到Viewmodel层
  • 条款22:将成员变量声明为private
  • PTA 7-224 sdut-C语言实验-排序问题
  • 【JavaScript】3.2 JavaScript性能优化
  • pytorch bert实现文本分类
  • 《开箱元宇宙》:Madballs 解锁炫酷新境界,人物化身系列大卖
  • 4K-Resolution Photo Exposure Correction at 125 FPS with ~8K Parameters
  • 网络初识:局域网广域网网络通信基础
  • JVM之jps虚拟机进程状态工具
  • C++实现顺序栈的基本操作(扩展)
  • 用python写一个简单的爬虫
  • 分布式追踪
  • make -c VS make -f