1-9 最长连续递增子序列 (20 分)

给定一个顺序存储的线性表,请设计一个算法查找该线性表中最长的连续递增子序列。例如,(1,9,2,5,7,3,4,6,8,0)中最长的递增子序列为(3,4,6,8)。

输入格式:

输入第1行给出正整数n(≤10^5​​ );第2行给出n个整数,其间以空格分隔。

输出格式:

在一行中输出第一次出现的最长连续递增子序列,数字之间用空格分隔,序列结尾不能有多余空格。

输入样例:

15
1 9 2 5 7 3 4 6 8 0 11 15 17 17 10

输出样例:

3 4 6 8

代码:

#include<stdio.h> #define N 1000000 struct node { int n;//存储线性表数据; int b;//储存递增个数; }s[N];//定义一个结构体数组; int main() { int a; scanf("%d",&a);//输入表的长度; int i,j; for(i=0;i<a;i++) { scanf("%d",&s[i].n);//将数据存入线性表; s[i].b=1;//递增次数都为1; } for(i=0;i<a-1;i++) { for(j=i+1;j<a;j++) { if(s[j].n>s[j-1].n) s[i].b++; else break; } } int c=1,d;//c为最大的递增次数,d为最长递增子序列开始位置; for(i=0;i<a;i++) { if(s[i].b>c)//连续递增的数的个数大于当前最大值 { c=s[i].b; d=i; } } for(i=d;i<c+d-1;i++) printf("%d ",s[i].n); printf("%d",s[c+d-1].n); }

__EOF__

本文作者坤舆小菜鸡
本文链接https://www.cnblogs.com/HBU-xuhaiyang/p/12520663.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   坤舆小菜鸡  阅读(144)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示