当前位置:首页 > 题解目录 > 正文内容

【题解】最长不下降子序列2

亿万年的星光2年前 (2023-05-13)题解目录3035

【题目描述】

设有由n(1≤n≤200)个不相同的整数组成的数列,记为:b(1)、b(2)、……、b(n)且b(i)≠b(j)(i≠j),若存在i1<i2<i3<…<ie 且有b(i1)<b(i2)<…<b(ie)则称为长度为e的不下降序列。程序要求,当原数列出之后,求出最长的不下降序列。

例如13,7,9,16,38,24,37,18,44,19,21,22,63,15。

例中13,16,18,19,21,22,63就是一个长度为7的不下降序列,同时也有7 ,9,16,18,19,21,22,63组成的长度为8的不下降序列。

【输入描述】

第一行为n,第二行为用空格隔开的n个整数。

【输出描述】

第一行为输出最大个数max。

第二行为max个整数形成的不下降序列,答案可能不唯一,输出一种就可以了。

【样例输入】

14
13 7 9 16 38 24 37 18 44 19 21 22 63 15

【样例输出】

max=8
7 9 16 18 19 21 22 63

【题目分析】

首先需要看一下前置文章:【题解】求最长不下降序列 - 青少年编程知识记录 (codecoming.com)

根据前面的这篇文章,剩下的部分是求出在最大长度下的一种解。那么应该如何求解呢?
我们已经知道了最大长度,而且已经知道了最大取最大长度时对应的下标值。我们可以倒叙求解,从长度最长那个开始,满足条件的数组放到一个新数组中,然后重新输出新数组。


#include<bits/stdc++.h>
using namespace std;
int a[1005]; //数据数组
int dp[1005]; //记录长度的数组
int res[1005]; //记录结果的数组
int main() {
	int n;
	int maxx=-9999;
	cin>>n;
	for(int i=1; i<=n; i++)
		cin>>a[i];
	for(int i=1; i<=n; i++) {
		dp[i]=1;
		for(int j=1; j<i; j++)
			if(a[j]<=a[i]) {
				dp[i]=max(dp[j],dp[j]+1);
			}
		if(dp[i]>maxx) {
			maxx=dp[i];
		}
	}
	cout<<"max="<<maxx<<endl;
	int index=1;
	int m=maxx; //把最大值赋给m,尽量不要去修改maxx的值。
	for(int i=n; i>=1; i--) {
		//逆序开始寻找最大值
		if(dp[i]==m) {
			res[index]=a[i];   //把符合条件的数据存到res数组中
			index++; //结果数组的下标加1
			m--; 	//最大值减1
		}
	}
	for(int i=index-1; i>=1; i--) {
		cout<<res[i]<<" ";
	}
	cout<<endl;
	return 0;
}


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

【题解】小x与队列

【题目描述】小X正和同学们做列队的练习。有n名同学排成一路纵队,编号为i的同学排在从前往后数第i个位置上,即:初始时的队列为1, 2, 3, ..., n。接下来小X会发出若干条指令,每条指令形如“请...

小苹果(apple)

【题目描述】小 Y 的桌子上放着n个苹果从左到右排成一列,编号为从1到n。小苞是小 Y 的好朋友,每天她都会从中拿走一些苹果。每天在拿的时候,小苞都是从左侧第1个苹果开始、每隔2个苹果拿走2个苹果。随...

【题解】Ride to Office

【题目描述】起点与终点相隔4500米。现Charley 需要从起点骑车到终点。但是,他有个习惯,沿途需要有人陪伴,即以相同的速度, 与另外一个人一起骑。而当他遇到以更快的速度骑车的人时,他会以相应的速...

【题解】约瑟夫问题2

【题解】约瑟夫问题2

【题目描述】M个人围成一圈,每分钟相邻的两个人可以交换位置(只能有一对交换)。求使M个人的顺序颠倒(即每个人左边相邻的人换到右边,右边相邻的人换到左边)所需的最少时间(分钟数)。【输入描述】 ...

【动态规划】完全背包

【题目描述】设有n种物品,每种物品有一个重量及一个价值。但每种物品的数量是无限的,同时有一个背包,最大载重量为m,今从n种物品中选取若干件(同一种物品可以多次选取),使其重量的和小于等于m,而价值的和...

【题解】游览动物园

【题目描述】动物园有很多游览区,小红已经在动物园的一个游览区游览,突然接到电话,要半个小时内到动物园外面跟一个朋友见面。半个小时小红只够游览完当前区域之后,游览一个最近的景区。已知从一个游览区域只能沿...