求一个数组中递增不减最长子数组

本文介绍了一个寻找数组中最长非降子数组的算法,并提供了一段C语言实现的代码示例。该算法通过遍历数组来确定最长的递增不减子数组,但其时间复杂度较高。文章最后提到了采用动态规划思想可以将时间复杂度降低至O(n)。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/************本模块功能如下************/
 
/*现在有一个数组 我们可以定义数组的子数组

如 数组 1 3 4 2 5 8 7
它的子数组可以是  1 3 4      3 4 2 5 等等

请写一个算法  找一个子数组  这个子数组递增不减少 并且是满足递增不减的最长子数组
*/


#include <stdio.h>
#include <stdlib.h>

int main()
{
 int n,i,k=0,len=1;
 int maxlen=1;    //保存最大递增不减子数组长度
 int first=0;     //保存递增不减子数组的首元素下标
 int low=0;       //保存最大递增不减子数组的首元素下标
 int *array;
 printf("请输入数组元素的个数:");
 scanf("%d\n",&n);
 if(n<=0)
 {
  printf("数组长度必须为正整数,请再次输入:");
  printf("请输入数组元素的个数:");
     scanf("%d\n",&n);
 }
 array=(int *)malloc(sizeof(int)*n);
 for(i=0;i<n;i++)
 {
  scanf("%d",&array[i]);
 }
// for(i=0;i<n;i++)
// {
//   printf("%d ",array[i]);
// }
 printf("\n");
    while(k<n)
 {  
  if(array[k+1]<array[k])
  {
   k++;
   len=1;
   continue;
  }
  while(array[k+1]>=array[k])
  {  
   if(len==1)
   {
    first=k;
   }
   len++;
   k++;
  }
  if(maxlen<len)
  {
   maxlen=len;
   low=first;
  }
 }
 printf("只増不减最长子数组长度是%d\n",maxlen);
 printf("只増不减最长子数组是:");
 for(i=low;i<low+maxlen;i++)
  printf("%d ",array[i]);
 printf("\n");
}

但是这个算法的时间复杂度是O(n*n),用动态规划的思想只需O(n)的时间复杂度!代码继续学习中。。。。。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值