递归、搜索与回溯-记忆化搜索:38.最长递增子序列

题目链接:300. 最长递增子序列(中等)

算法原理:

解法:DFS

Java代码:

java 复制代码
import java.util.Arrays;

/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-10-10
 * Time: 21:51
 */
class Solution {
    //300. 最长递增子序列
    //吴小哲的递归解法(记忆化搜索在新增的1.2处)
    int n;
    public int lengthOfLIS(int[] nums) {
        //递归版本+记忆化搜索版本
        n=nums.length;int ret=0;
        int[] memo=new int[n];
        for(int i=0;i<n;i++) ret=Math.max(ret,dfs(nums,i,memo));
        return ret;

        //动态规划版本
        n=nums.length;int ret=0;
        int[] dp=new int[n];
        Arrays.fill(dp,1);//自己本身就是一个长度
        //填表顺序:从后向前
        //dp表中的每一个数据都代表从此往后的最长长度
        for(int i=n-1;i>=0;i--){
            for(int j=i+1;j<n;j++){
                if(nums[j]>nums[i])//我这里不太熟练
                    dp[i]=Math.max(dp[i],dp[j]+1);
            }
            ret=Math.max(ret,dp[i]);
        }
        //int[] memo=new int[n];
        //for(int i=0;i<n;i++) ret=Math.max(ret,dfs(nums,i,memo));
        return ret;
    }
    public int dfs(int[] nums,int pos,int[] memo){
        //记忆化搜索新增1:如果备忘录里有就直接返回
        if(memo[pos]!=0) return memo[pos];
        int ret=1;
        for(int i=pos+1;i<n;i++)
            if(nums[i]>nums[pos])
                ret=Math.max(ret,dfs(nums,i,memo)+1);
        //记忆化搜索新增2:返回前存一下备忘录
        memo[pos]=ret;
        return ret;
    }
}
相关推荐
Seven9720 小时前
【从0到1构建一个ClaudeAgent】规划与协调-子Agent
java
智者知已应修善业20 小时前
【51单片机独立按键控制数码管动态显示和LED间隔闪烁并清零】2023-5-28
c语言·经验分享·笔记·算法·51单片机
宠友信息20 小时前
社交软件源码哪个渠道好
java·微服务·架构·社交电子·springboot·uniapp
improvement...20 小时前
Maven 编译打包全指南:整体 / 逐个打包 + 核心参数详解
java·maven
_李小白20 小时前
【OSG学习笔记】Day 41: ReadFileCallback 与 WriteFileCallback(自定义文件读取)
java·笔记·学习
每天吃饭的羊20 小时前
nest,java对比
java·开发语言
组合缺一20 小时前
SolonCode CLI v2026.4.11 发布(中文驱动的编码智能体)
java·ai编程·agents·solon-ai·claudecode·opencode·soloncode
大佐不会说日语~20 小时前
Spring AI Alibaba 的 Function Calling 使用 @Tool 调用中,无法获取用户ID踩坑记录
java·人工智能·spring boot·spring·alibaba·function
Java基基20 小时前
Maven 4要来了:15年后,Java构建工具迎来“彻底重构”
java·开发语言·重构
zhanghongbin0120 小时前
Remote Write:高效数据推送
java·人工智能