算法学习day30-贪心算法

用最少数量的箭引爆气球

核心思路

  • 这道题贪心的点在于, 让气球尽可能多的有重合的部分, 这样就可以一箭射穿

  • 先根据左边界排序, 再判断 下个气球的左边界和上个气球的右边界是否有重合的部分, 有的话, 就能一箭射穿

    • 注意, 这里要更新重合部分的边界, 重合部分的边界是: [当前气球的左边界, 两个气球的最小的右边界]
  • 如果没有重合的部分, 那就从当前气球开始重新寻找重合的边界

    java 复制代码
    public static int findMinArrowShots(int[][] points) {
        Arrays.sort(points, Comparator.comparingInt(a -> a[0]));
        int res = 1;
        int rightBian = points[0][1];
        for (int i = 1; i < points.length; i++) {
            int[] point = points[i];
            int left = point[0];
            int right = point[1];
            if (left > rightBian) {
                res++;
                rightBian = right;
            } else {
                rightBian = Math.min(right, rightBian);
            }
        }
        return res;
    }

无重叠区间

核心思路

  • 和射气球思路类似, 如果重叠就移除, 不重叠, 就用新的右边界继续判断是否重叠

    java 复制代码
    public int eraseOverlapIntervals(int[][] intervals) {
        Arrays.sort(intervals, Comparator.comparingInt(a -> a[0]));
        int preRight = intervals[0][1];
        int count = 0;
        for (int i = 1; i < intervals.length; i++) {
            int[] ints = intervals[i];
            int left = ints[0];
            int right = ints[1];
            if (left < preRight) {
                count++;
                preRight = Math.min(right, preRight);
            } else {
                preRight = right;
            }
        }
        return count;
    }

划分字母区间

核心思路

  • 找到每个字母的最大区间范围, 如果下个字母和上个字母有重叠, 那就取最小left和最大right作为新的区间, 继续判断

    java 复制代码
    public List<Integer> partitionLabels(String s) {
        int left = 0;
        int right = 0;
        int[] fastIndex = new int[26];
        char[] charArray = s.toCharArray();
        for (int i = 0; i < charArray.length; i++) {
            fastIndex[charArray[i] - 'a'] = i;
        }
        List<Integer> res = new ArrayList<>();
        for (int i = 0; i < charArray.length; i++) {
            int index = fastIndex[charArray[i] - 'a'];
            if (i <= right) {
                left = Math.min(i, left);
                right = Math.max(index, right);
            } else {
                res.add(right - left + 1);
                left = i;
                right = index;
            }
        }
        res.add(right - left + 1);
        return res;
    }
相关推荐
iAkuya19 小时前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
近津薪荼19 小时前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
xiaoye-duck19 小时前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl
松☆19 小时前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型
java干货19 小时前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法
皮皮哎哟19 小时前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
程序员清洒19 小时前
CANN模型剪枝:从敏感度感知到硬件稀疏加速的全链路压缩实战
算法·机器学习·剪枝
敏叔V58719 小时前
AI智能体的工具学习进阶:零样本API理解与调用
人工智能·学习
vortex520 小时前
几种 dump hash 方式对比分析
算法·哈希算法
2501_9418649620 小时前
科学方法论破解学习时间堆砌误区
学习