首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >数组的最长的、后续的、升序的子序列

数组的最长的、后续的、升序的子序列
EN

Stack Overflow用户
提问于 2015-05-20 04:39:03
回答 1查看 106关注 0票数 2

我被大学的作业卡住了。任务是找到一种递归然后动态编程的方法来计算数组中最长的、后续的、升序的子序列的长度。例如,如果数组为:{4,- 5,-3,-2,5,-2,0,3,2},则最大长度为4,子序列为{-5,-3,-2,5}。我很难找到递归的方式,没有递归的方式,我就不可能找到动态的方式。

我尝试过编程,但我知道它是错误的,我不确定如何修复它:

代码语言:javascript
复制
public static int length(int[] arr,int j)
{
    if(arr.length == 1)
    {
        return 1;
    }
    if(j == 1)
    {
        if(arr[j-1] < arr[j])
        {
            return 1;
        }
        else
        {
            return 0;
        }
    }
    else
    {
        int c = length(arr,j-1);
        if(arr[j-1] < arr[j])
        {
            return 1 + c;
        }
        else
        {
            return 0;
        }
    }
}
EN

回答 1

Stack Overflow用户

发布于 2015-05-20 22:12:23

试试这个:

代码语言:javascript
复制
int length(int index, int previous)
    {
       if(arr.length == (index+1))
            return 0;
       else 
           if(arr[index] > previous)
               return 1+length(index+1,arr[index]);
           else return length(index+1,previous)
    }

也许您不需要在每次递归调用中都通过创建静态变量来将数组作为参数提供,

Previous是子序列的最新元素

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30335684

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档