当前位置: 首页 > news >正文

贪心算法(16)(java)俄罗斯套娃信封问题

题目:给你一个二维整数数组 envelopes ,其中 envelopes[i] = [wi, hi] ,表示第 i 个信封的宽度和高度。

当另一个信封的宽度和高度都比这个信封大的时候,这个信封就可以放进另一个信封里,如同俄罗斯套娃一样。

请计算 最多能有多少个 信封能组成一组“俄罗斯套娃”信封(即可以把一个信封放到另一个信封里面)。

注意:不允许旋转信封。

 

示例 1:

输入:envelopes = [[5,4],[6,4],[6,7],[2,3]]
输出:3
解释:最多信封的个数为 3, 组合为: [2,3] => [5,4] => [6,7]。

示例 2:

输入:envelopes = [[1,1],[1,1],[1,1]]
输出:1j

解法1:常规解法->动态规划

步骤:1.状态表示 2.状态转移方程  3.初始化  4.填表顺序  5.返回值

import java.util.Arrays;

public class Solution {
    public int maxEnvelopes(int[][] e) {
        Arrays.sort(e,(v1,v2)->
        {
            return v1[0] - v2[0];
        });
        int n=e.length;
        int[]dp=new int[n];
        int ret=1;
        for (int i=1;i<n;i++)
        {
            dp[i]=1;
            for (int j=0;j<i;j++)
            {
             if (e[i][0]>e[j][0]&&e[i][1]>e[j][1])
             {
                 dp[i]=Math.max(dp[i],dp[i]+1);
             }
            }
            ret=Math.max(ret,dp[i]);
        }
        return ret;
    }

    public static void main(String[] args) {
        Solution solution=new Solution();
        int [][] e={{5,4},{6,4},{6,7},{2,3}};
        System.out.println(solution.maxEnvelopes(e));
    }
}

解法2:重写排序+贪心+二分

重写排序:1.当左端点不同的时候,按左端点从小到大的顺序排列;

                  2.当左端点相同的时候,按右端点从大到小的顺序排列;

import java.util.ArrayList;
import java.util.Arrays;

public class Solution2 {
    public int maxEnvelopes(int[][] e){
        Arrays.sort(e,(v1,v2)->
        {
            return v1[0]!=v2[0]?v1[0]-v2[0]:v2[1]-v1[1];

        });
        ArrayList<Integer>ret=new ArrayList<>();
        ret.add(e[0][1]);
        for (int i=1;i<e.length;i++)
        {
            int b=e[i][1];
            if(b>ret.get(ret.size()-1))
            {
                ret.add(b);
            }
            else {
                int left=0,right=ret.size()-1;
                while(left>right)
                {
                    int mid=(left+right)/2;
                    if(ret.get(mid)>=b)right=mid;
                    else left=mid+1;

                }
                ret.set(left,b);
            }
        }
        return ret.size();
    }

    public static void main(String[] args) {
        Solution solution1=new Solution();
        int[][] e={{5,4},{6,4},{6,7},{2,3}};
        System.out.println(solution1.maxEnvelopes(e));
    }
}

相关文章:

  • 从零到一:用Java和Spring Security构建OAuth2授权服务器
  • 【Vue-vue基础知识】学习笔记
  • 强化学习Q-Learning:DQN
  • 17-产品经理-创建发布
  • Golang 项目平滑重启
  • Python小练习系列 Vol.13:用装饰器记录函数执行时间
  • 蓝桥杯2024年第十五届省赛真题-爬山
  • 刺杀大使--bfs还是比dfs快+二分
  • 专题|MATLAB-R语言Logistic逻辑回归增长模型在互联网金融共生及移动通信客户流失分析实例合集
  • 基于Python Flask快速构建网络安全工具资源库的Web应用实践
  • 【简历全景认知2】电子化时代对简历形式的降维打击:从A4纸到ATS的生存游戏
  • Python高阶函数-filter
  • es 原生linux部署集群
  • JS 中html的document
  • MySQL学习笔记六
  • Python爬虫生成CSV文件的完整流程
  • 谷歌洽谈租赁英伟达AI服务器:算力争夺战再升级
  • 过剩与稀缺:现代社会的思考与启示
  • 信息系统项目管理师-第十一章-项目成本管理
  • R语言:气象水文领域的数据分析与绘图利器
  • 鸿蒙电脑正式发布,国产操作系统在个人电脑领域实现重要突破
  • “马上涨价”再到“吞下关税”,美政策让沃尔玛“输两次”
  • 知名中医讲师邵学军逝世,终年51岁
  • 为何选择上海?两家外企提到营商环境、人才资源……
  • 125%→10%、24%税率暂停90天,对美关税开始调整
  • 大外交|巴西总统卢拉第六次访华签署20项协议,“双方都视对方为机遇”