贪心算法: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();
    }
}
相关推荐
s1hiyu20 小时前
实时控制系统验证
开发语言·c++·算法
daad77720 小时前
V4L2_mipi-csi
算法
2301_7657031420 小时前
C++代码复杂度控制
开发语言·c++·算法
m0_7088309620 小时前
C++中的享元模式实战
开发语言·c++·算法
naruto_lnq20 小时前
分布式计算C++库
开发语言·c++·算法
Hx_Ma1620 小时前
Map集合的5种遍历方式
java·前端·javascript
小手cool20 小时前
Java 列表中查找最小值和最大值最有效率的方法
java
惊讶的猫20 小时前
多线程同步问题及解决
java·开发语言·jvm
wfsm20 小时前
工厂模式创建动态代理实现类
java·开发语言
好好研究20 小时前
总结SSM设置欢迎页的方式
xml·java·后端·mvc