贪心算法:5.最长递增子序列

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

算法原理:

解法+交换论证证明:贪心

Java代码:

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

/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-11-01
 * Time: 00:02
 */
class Solution {
    //300.最长递增子序列
    public int lengthOfLIS(int[] nums) {
        //贪心解法:自己真写不出来,看了吴小哲的代码还琢磨琢磨才弄上的
        //当已经是2.4.7.13时再来个8是把13覆盖掉的
        ArrayList<Integer> ret=new ArrayList<>();
        int n=nums.length;
        ret.add(nums[0]);
        for(int i=1;i<n;i++){
            if(nums[i]>ret.get(ret.size()-1)) ret.add(nums[i]);
            else{
                int left=0,right=ret.size()-1;
                while(left<right){
                    int mid=(left+right)/2;
                    if(ret.get(mid)<nums[i]) left=mid+1;
                    else right=mid;
                }
                ret.set(left,nums[i]);
            }
        }
        return ret.size();
    }
}
相关推荐
苏渡苇5 分钟前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·设计模式·学习方法·责任链模式
团子的二进制世界12 分钟前
G1垃圾收集器是如何工作的?
java·jvm·算法
吃杠碰小鸡16 分钟前
高中数学-数列-导数证明
前端·数学·算法
故事不长丨16 分钟前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
long31617 分钟前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
近津薪荼18 分钟前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
熊文豪26 分钟前
探索CANN ops-nn:高性能哈希算子技术解读
算法·哈希算法·cann
熊猫_豆豆43 分钟前
YOLOP车道检测
人工智能·python·算法
rannn_11144 分钟前
【苍穹外卖|Day4】套餐页面开发(新增套餐、分页查询、删除套餐、修改套餐、起售停售)
java·spring boot·后端·学习
灵感菇_1 小时前
Java HashMap全面解析
java·开发语言