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

动态规划——最长非降子序列

该问题的思路及应用可参考动态规划——导弹拦截

最长非降子序列
Time Limit: 5000 MSMemory Limit: 5000 KB

Description

给定一个长度为N的整数数组, 请计算该数组中最长非降了序列长度。

Input

第一行输入M(M<=10)表示有M组数据。每组数据输入N(N<=10000), 接下来输入N个整数。

Output

输出M行正整数,第i行表示第i组数据的长非降了序列长度。

Sample Input

2
4 
1 3 2 4
9
4 1 7 3 2 3 5 7 6

Sample Output

3
5

注意非降!!!,而不是增长

#include<iostream>
using namespace std;
int main() {
	int T, N;                //T组,每组N个
	cin >> T;               //组数
	for (int i = 0; i < T; i++) {
		cin >> N;           //每组N个数


		//动态规划
		int* d= new int[N]; //d[i]表示第i个数之后序列的最长非降子序列长度(包括第i个)
		int* x = new int[N]; //x[i]表示第i个数

		for (int i = 0; i < N; i++) {
			cin >> x[i];
			d[i] = 1;     //d[i]初始化为1
			
		}
		for (int i = 0; i <N; i++) {  //从后向前,开始依次计算最长子序列(由已知推未知)
			for (int j =0; j < i; j++) {   //遍历i之前的所有值,确保i找到的是[0,i-1]中的的最长子序列
				if (x[i] >= x[j] && d[i] < d[j] + 1)
				{
					d[i] = d[j] + 1;
				}
				//如果第j个数小于第i个且d[i]>=d[j]+1,则d[i]=d[j]+1;依次向后循环,直到找到最大的d[j]+1,将其赋值为d(i)
			}
		}
		int max = 0;

		for (int i = 0; i < N; i++) {
			if (d[i] > max) { max = d[i]; }
		}
        	cout << max <<  endl;  //循环后d[0]对应的一定是其最长子序列
	}
	return 0;
}


http://www.kler.cn/a/13766.html

相关文章:

  • 司空见惯 - 参加VOE问卷调查
  • Nginx之正则表达式、location匹配简介以及rewrite重写
  • TortoiseSVN使用-权限配置
  • 机器思维(个人总结)
  • 【U8+】用友U8+对账不平案例及方法总结
  • 获得将要生成的资源的GUID
  • js 把base64转file文件
  • 基于高德导航的大作业
  • 在更高的起点创业 专访Aqara重庆服务商,探问「经营秘籍」
  • NFC 学习笔记 5 MFRC522读写器2 NDEF
  • 互联网摸鱼日报(2023-04-20)
  • Matlab 相机标定
  • “行泊舱”+出海全面发力,这家ADAS厂商跑出规模化“新速度”
  • deepstream的nvv4l2h264enc硬编码插件讲解,实现rtsp推流,且无延迟
  • 153. 寻找旋转排序数组中的最小值
  • 电子工程有哪些SCI期刊推荐? - 易智编译EaseEditing
  • Python面试题常用函数总结
  • 【人工智能概论】 RNN、LSTM、GRU简单入门与应用举例、代码耗时计算
  • 《花雕学AI》24:如何用万能Prompt公式与ChatGPT进行高效的对话测试
  • 卖房子真是稳赚不赔