问题 H: 超级跳跳跳1281
这道题其实本身有点超纲,有点涉及动态规划的内容了,即求最大上升子序列的最大的和
写不出来很正常,不用觉得自己菜哈哈哈哈哈,实在不彳亍跳过也是可以的,那我就直接放代码了
点击查看代码
#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;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现