贪心算法: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();
    }
}
相关推荐
无限进步_12 小时前
【数据结构&C语言】对称二叉树的递归之美:镜像世界的探索
c语言·开发语言·数据结构·c++·算法·github·visual studio
zhglhy12 小时前
Spring Data Slice使用指南
java·spring
im_AMBER12 小时前
Leetcode 98 从链表中移除在数组中存在的节点
c++·笔记·学习·算法·leetcode·链表
win x12 小时前
Redis 主从复制
java·数据库·redis
weixin_4239950012 小时前
unity 处理图片:截图,下载,保存
java·unity·游戏引擎
帅气的你12 小时前
从零封装一个通用的 API 接口返回类:统一前后端交互格式
java·设计模式
qq_1780570712 小时前
基于minio实现的分片上传-支持断点续传
java
高山上有一只小老虎12 小时前
灵异背包?
java·算法
码农水水12 小时前
大疆Java面试被问:TCC事务的悬挂、空回滚问题解决方案
java·开发语言·人工智能·面试·职场和发展·单元测试·php
qq_25183645712 小时前
基于java Web 个人网站系统设计与实现
java·开发语言·数据库