首页 > 其他分享 >问题 H: 超级跳跳跳1281

问题 H: 超级跳跳跳1281

时间:2022-11-10 09:11:45浏览次数:49  
标签:1281 跳跳 超级 ++ int scanf 1000


这道题其实本身有点超纲,有点涉及动态规划的内容了,即求最大上升子序列的最大的和
写不出来很正常,不用觉得自己菜哈哈哈哈哈,实在不彳亍跳过也是可以的,那我就直接放代码了

点击查看代码
#include<stdio.h>
int main(void)
{
	int n;
	int a[1000];
	int i;
	int j;
	while (1)
	{
		scanf_s("%d", &n);
		int x[1000] = { 0 };
		if (n == 0)
		{
			break;
		}
		else
		{
			for (i = 0; i < n; i++)
			{
				scanf("%d", &a[i]);
			}
			x[0] = a[0];//x[i]数组代表数组的i个元素里面的最大上升序列子段和
			for (i = 1; i < n; i++)
			{
				for (j = 0; j < i; j++)
				{
					if (a[i] > a[j] && x[i] < x[j] + a[i])//这里就有点用到动态规划的思想了,也就是到第i个的最大和可能还小于第j个的最大和加上a[i]。
					{
						x[i] = a[i] + x[j];
					}
					if (a[i] <= a[j])
					{
						if (x[i] < a[i])//如果前i个的最大上升子段和比第a[j]个的元素还要小。那么x[i]就是等于a[i]。
						{
							x[i] = a[i];
						}
					}
				}
			}
			int max = 0;
			for (i = 0; i < n; i++)
			{
				if (max < x[i])
				{
					max = x[i];//这里的意思是  如果题目有负数,那么不如直接从开头跳到结尾---0。
				}
			}
			printf("%d\n", max);
		}
	}
	return 0;
}

标签:1281,跳跳,超级,++,int,scanf,1000
From: https://www.cnblogs.com/myy-zzb/p/16875917.html

相关文章