代码随想录第36、37天| 435. 无重叠区间 763.划分字母区间 56. 合并区间

news2024/11/30 6:38:31

 435. 无重叠区间

435. 无重叠区间 - 力扣(LeetCode)

代码随想录 (programmercarl.com)

贪心算法,依然是判断重叠区间 | LeetCode:435.无重叠区间_哔哩哔哩_bilibili

给定一个区间的集合 intervals ,其中 intervals[i] = [starti, endi] 。返回 需要移除区间的最小数量,使剩余区间互不重叠 

示例 1:

输入: intervals = [[1,2],[2,3],[3,4],[1,3]]
输出: 1
解释: 移除 [1,3] 后,剩下的区间没有重叠。

示例 2:

输入: intervals = [ [1,2], [1,2], [1,2] ]
输出: 2
解释: 你需要移除两个 [1,2] 来使剩下的区间没有重叠。

示例 3:

输入: intervals = [ [1,2], [2,3] ]
输出: 0
解释: 你不需要移除任何区间,因为它们已经是无重叠的了。

提示:

  • 1 <= intervals.length <= 105
  • intervals[i].length == 2
  • -5 * 104 <= starti < endi <= 5 * 104

 没看卡哥题解,自己的想法就是先把区间从小到大排序,具体就是比较区间的最左边的值,也就是区间的最小值,最小值小的排前面。然后遍历每个区间,将第i个区间的left和第i-1区间的right值比较大小,left<=right则没有重叠,反之则有重叠,count++:

class Solution { // 定义一个类Solution
    public int eraseOverlapIntervals(int[][] intervals) { // 定义一个公有方法eraseOverlapIntervals,接受一个二维整数数组intervals作为参数,并返回一个整数值
        Arrays.sort(intervals, (a,b)-> { // 使用Arrays.sort对intervals进行排序,排序规则是按照子数组的第一个元素升序排列
            return Integer.compare(a[0],b[0]); // 比较两个子数组的第一个元素的大小,返回比较结果
        });
        int remove = 0; // 初始化变量remove为0,用于记录需要移除的重叠区间数量
        int pre = intervals[0][1]; // 初始化变量pre为第一个区间的结束位置,用于记录上一个不重叠的区间的结束位置
        for(int i = 1; i < intervals.length; i++) { // 循环遍历intervals数组,从第二个区间开始
            if(pre > intervals[i][0]) { // 如果上一个区间的结束位置大于当前区间的开始位置,表示存在重叠
                remove++; // 计数器remove加1,表示需要移除一个重叠区间
                pre = Math.min(pre, intervals[i][1]); // 更新上一个不重叠区间的结束位置为当前区间的结束位置和上一个区间结束位置的较小值
            }
            else pre = intervals[i][1]; // 如果当前区间不与上一个区间重叠,则更新上一个不重叠区间的结束位置为当前区间的结束位置
        }
        return remove; // 返回需要移除的重叠区间数量
    }
}

763.划分字母区间 

763. 划分字母区间 - 力扣(LeetCode)

代码随想录 (programmercarl.com)

贪心算法,寻找最远的出现位置! LeetCode:763.划分字母区间_哔哩哔哩_bilibili

给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。

注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍然是 s 。

返回一个表示每个字符串片段的长度的列表。

示例 1:

输入:s = "ababcbacadefegdehijhklij"
输出:[9,7,8]
解释:
划分结果为 "ababcbaca"、"defegde"、"hijhklij" 。
每个字母最多出现在一个片段中。
像 "ababcbacadefegde", "hijhklij" 这样的划分是错误的,因为划分的片段数较少。 

示例 2:

输入:s = "eccbbbbdec"
输出:[10]

提示:
  • 1 <= s.length <= 500
  • s 仅由小写英文字母组成

这个题第一想法就是双指针法,一个指针i指向区间开头的字母,另外一个指针j从区间最左边向右遍历,直到找到和第一个字母相同的字母,返回这个字母的下标,然后指针i向右移动一位,指针j从原地右移;如果没找到,就把左边的指针i向后移动一位,重复上述过程。指针i和指针j的位置就是需要切割的位置。

写完发现好乱。。。。还是看卡哥题解吧。。

🤓看了卡哥题解后发现我有2点没弄清楚所以导致很乱:

1、区间与区间之间一定是不重合的,所以下一个区间起始的位置一定在上一个区间结束位置的后面

2、我最大的问题在于用双指针法很糊。不建议用双指针法,直接标出每个字母的下标,某字母下标最大的位置就是这个字母最远的位置,必须包括在同一个区间内,如图:

卡哥还有一点很巧妙的就是将字母转换成数字做减法,整体代码如下:

class Solution {
    public List<Integer> partitionLabels(String S) {
        // 创建一个列表来存储分区的长度
        List<Integer> list = new LinkedList<>();
        
        // 初始化一个数组来存储每个字符在字母表中的最后出现位置的索引
        int[] edge = new int[26];
        
        // 将输入字符串转换为字符数组
        char[] chars = S.toCharArray();
        
        // 遍历字符串的字符,存储每个字符的最后出现位置的索引
        for (int i = 0; i < chars.length; i++) {
            edge[chars[i] - 'a'] = i;
        }
        
        // 初始化变量来跟踪当前索引和当前分区的最后一个索引
        int idx = 0;
        int last = -1;
        
        // 再次遍历字符串的字符
        for (int i = 0; i < chars.length; i++) {
            // 更新当前分区的最后一个索引
            idx = Math.max(idx, edge[chars[i] - 'a']);
            
            // 如果当前索引等于当前分区的最后一个索引,
            // 这意味着我们已经到达当前分区的末尾
            if (i == idx) {
                // 将当前分区的长度添加到列表中
                list.add(i - last);
                
                // 更新当前分区的最后一个索引
                last = i;
            }
        }
        
        // 返回包含分区长度的列表
        return list;
    }
}

 56. 合并区间

56. 合并区间 - 力扣(LeetCode)

代码随想录 (programmercarl.com)

贪心算法,合并区间有细节!LeetCode:56.合并区间_哔哩哔哩_bilibili

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。

示例 1:

输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].

示例 2:

输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。

提示:

  • 1 <= intervals.length <= 104
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 104

先按左边界的值排序:

发现重合后其实只需要更新右边界:

// 更新最右边界为当前区间右边界和原最右边界的较大值
                rightmostRightBound = Math.max(rightmostRightBound, intervals[i][1]);

综合代码:

class Solution {
    public int[][] merge(int[][] intervals) {
        // 创建一个列表来存储合并后的区间
        List<int[]> res = new LinkedList<>();
        
        // 按照区间的左边界进行排序
        Arrays.sort(intervals, (x, y) -> Integer.compare(x[0], y[0]));
        
        // 初始化 start 为第一个区间的左边界
        int start = intervals[0][0];
        // 初始化最右边界为第一个区间的右边界
        int rightmostRightBound = intervals[0][1];
        
        // 遍历区间数组
        for (int i = 1; i < intervals.length; i++) {
            // 如果当前区间的左边界大于当前最右边界
            if (intervals[i][0] > rightmostRightBound) {
                // 将当前区间合并到结果中,并更新 start 和最右边界
                res.add(new int[]{start, rightmostRightBound});
                start = intervals[i][0];
                rightmostRightBound = intervals[i][1];
            } else {
                // 更新最右边界为当前区间右边界和原最右边界的较大值
                rightmostRightBound = Math.max(rightmostRightBound, intervals[i][1]);
            }
        }
        
        // 添加最后一个合并后的区间到结果中
        res.add(new int[]{start, rightmostRightBound});
        
        // 将结果列表转换为数组并返回
        return res.toArray(new int[res.size()][]);
    }
}

 

 738.单调递增的数字

738. 单调递增的数字 - 力扣(LeetCode)

代码随想录 (programmercarl.com)

贪心算法,思路不难想,但代码不好写!LeetCode:738.单调自增的数字_哔哩哔哩_bilibili

注意点:

1、这个题要注意从后往前遍历。

2、传进来的数值是int类型,为了方便各个位上的数值比较大小,将int类型转为字符串。

3、start记录位置,start后面的都赋值为9才能得到最大值

4、start初始为s的长度而不是0,为的就是避免s=1234这种情况出现时,再走for (int i = start; i < s.length(); i++) {
            chars[i] = '9'; 的逻辑将s变成1999.

class Solution {
    public int monotoneIncreasingDigits(int n) {
        // 将输入的整数转换为字符串
        String s = String.valueOf(n);
        
        // 将字符串转换为字符数组
        char[] chars = s.toCharArray();
        
        // 初始化变量 start 为字符串的长度
        int start = s.length();
        
        // 从倒数第二位开始向前遍历字符数组
        for (int i = s.length() - 2; i >= 0; i--) {
            // 如果当前字符大于后面一位字符
            if (chars[i] > chars[i + 1]) {
                // 将当前字符减去1,并更新 start 的值为当前位置的后一位
                chars[i]--;
                start = i + 1;
            }
        }
        
        // 将 start 位置后的所有字符设为 '9'
        for (int i = start; i < s.length(); i++) {
            chars[i] = '9';
        }
        
        // 将字符数组转换为整数并返回
        return Integer.parseInt(String.valueOf(chars));
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1586348.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python项目1 外星人入侵_外星人

在本章中&#xff0c;我们将在游戏《外星人入侵》中添加外星人。首先&#xff0c;我们在屏幕上边缘附近添加一个外星人&#xff0c;然后生成一群外星人。我们让这群外星人向两边和下面移 动&#xff0c;并删除被子弹击中的外星人。最后&#xff0c;我们将显示玩家拥有的飞船数量…

C/C++基础----运算符

算数运算符 运算符 描述 例子 两个数字相加 两个变量a b得到两个变量之和 - 两个数字相减 - * 两个数字相乘 - / 两个数字相除 - % 两个数字相除后取余数 8 % 3 2 -- 一个数字递减 变量a&#xff1a;a-- 、--a 一个数字递增 变量a: a 、 a 其中递…

容错组合导航

在初始值正确的情况下&#xff0c;惯性导航短期精度较高&#xff0c;但是其误差随着时间是累计的。如果要提高惯性导航的长期精度&#xff0c;就必须提高惯性器件的精度和初始读准精度&#xff0c;这必将大大提高成本。 如果将惯性导航与其他导航系统适当地组合起来&#xff0c…

开源项目若依放大招了?

前言 鉴于之前写了篇插件式相关的文章&#xff0c;阅读量比起其它文章可不要好太多&#xff0c;所以我决定继续这个主题&#xff01; 以前我们公司用的就是Ruoyi&#xff0c;代码比较简单易懂。但是有些功能确实用不上&#xff0c;比如部门和岗位&#xff0c;每次新项目我拉了…

Web程序设计-实验02 CSS页面布局

【实验主题】 影视网站前台模板页设计 【实验任务】 1、浏览并分析多个影视网站&#xff08;详见参考资源&#xff0c;建议自行搜索更多影视网站&#xff09;的整体版面布局&#xff0c;对比同一网站不同页面&#xff08;主页、列表页、详情页&#xff09;的元素异同——剔除…

探索ChatGPT-Plus:AI 助手全套开源解决方案

探索ChatGPT-Plus&#xff1a;AI 助手全套开源解决方案 ChatGPT-plus是一种新型的对话生成模型&#xff0c;它是在OpenAI的ChatGPT基础上进行了改进和优化的版本。ChatGPT-plus的出现引起了广泛关注&#xff0c;因为它在对话生成方面展现出了更加出色的表现和能力。在本文中&am…

MobX 中 runInAction 的威力:构建原子性状态更新

"原子性状态更新"这个词可以很好地概括 runInAction 的核心功能,即将一组相关的状态更新作为一个整体,要么全部成功,要么全部失败。这种特性对于复杂的异步操作和状态管理非常重要。可以帮助我们构建更加可靠和可预测的 React 应用程序。 怎么理解原子性操作 "…

动态调整学习率方法(仅供自己学习)

目录 一、StepLR 二、MultiStepLR 三、ExponentialLR 四、CosineAnnealingLR 五、ReduceLRonPlateau 六、LambdaLR 小结&#xff1a;学习率调整​​​​​​​ 一、StepLR optimizer torch.optim.SGD(model.parameters(), lrlearn_rate) scheduler torch.optim.lr_sch…

linux重定向符号

将ls命令执行结果重定向到a文件中 将错误ls命令执行结果重定向到a文件中&#xff08;这里用到前面的标准错误输出重定向&#xff09;

【C++初阶】C++简单入门(长期维护)

本篇博客是对C的一些简单知识分享&#xff0c;有需要借鉴即可。 C简单入门目录 一、C前言1.C的概念&#xff1a;2.C发展历程3.C如何学&#xff1f; 二、C入门1.C关键字(C98标准)2.命名空间3.C输入&输出①概念说明②使用说明③特征说明④细节拓展⑤cout与cin的意义 4.缺省参…

【24年软考】系统架构设计师论文写作技巧(附范文10篇)

1.快速审题 写作文要先审题&#xff0c;架构师论文命题也是如此。论文命题除了确定题目之外&#xff0c;还会给你写作要求。而这个写作要求会告诉你本命题涉及的知识点有哪些&#xff0c;并给你确立一个写作向。这个可以参考后面的论文真题分析。 2.确定题目 在填写并确认好…

MATLAB有限元结构动力学分析与工程应用-徐斌|【PDF电子书+配套Matlab源码】

专栏导读 作者简介&#xff1a;工学博士&#xff0c;高级工程师&#xff0c;专注于工业软件算法研究本文已收录于专栏&#xff1a;《有限元编程从入门到精通》本专栏旨在提供 1.以案例的形式讲解各类有限元问题的程序实现&#xff0c;并提供所有案例完整源码&#xff1b;2.单元…

wsl 2在windows11上的设置

详细参考&#xff1a;Manual installation steps for older versions of WSL | Microsoft Learn 1.系统组件要打开 分别是&#xff1a;Hyper-V、虚拟机平台、适用于Windows的Linux子系统 2.以管理员方式运行命令行&#xff0c;逐步执行下面的命令 update to WSL 2, you must…

篮球竞赛|基于Springboot的篮球竞赛预约平台系统设计与实现(源码+数据库+文档)

篮球竞赛预约平台目录 基于Springboot的篮球竞赛预约平台系统设计与实现 一、前言 二、系统设计 三、系统功能设计 1、前台&#xff1a; 2、后台 管理员功能 用户功能 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff…

llama-factory SFT系列教程 (一),大模型 API 部署与使用

文章目录 背景简介难点 前置条件1. 大模型 api 部署下一步阅读 背景 本来今天没有计划学 llama-factory&#xff0c;逐步跟着github的文档走&#xff0c;发现这框架确实挺方便&#xff0c;逐渐掌握了一些。 最近想使用 SFT 微调大模型&#xff0c;llama-factory 是使用非常广泛…

主从数据同步原理

2.2.主从数据同步原理 2.2.1.全量同步 主从第一次建立连接时&#xff0c;会执行全量同步&#xff0c;将master节点的所有数据都拷贝给slave节点&#xff0c;流程&#xff1a; 这里有一个问题&#xff0c;master如何得知salve是第一次来连接呢&#xff1f;&#xff1f; 有几个…

添加索引真的不会锁表吗

1.MySQL DDL执行方式 MySQL5.5以及之前的版本&#xff0c;通常更改数据表结构操作(DDL)会阻塞对表数据的增删改操作(DML)。 MySQL5.6提供Online DDL之后可支持DDL与DML操作同时执行&#xff0c;降低了DDL期间对业务延迟带来的影响。 2.Online ddl&#xff1a; 概念&#xff…

Innodb架构解析

整体架构 通过《面试官&#xff1a;一条SQL是如何执行的&#xff1f;》我们了解了MySQL架构&#xff0c;下面我们看下Innodb架构。 innodb最早由Innobase Oy公司开发&#xff0c;5.5版本开始是MySQL默认存储引擎&#xff0c;该存储引擎是第一个完整支持ACID事务的MySQL存储引…

多线程GUI界面文件复制程序的解决方案

在Python中&#xff0c;你可以使用多线程来编写一个GUI界面的文件复制程序。这样可以使得文件复制过程在后台进行&#xff0c;而不会阻塞用户界面&#xff0c;提升用户体验。下面是一个使用Python的Tkinter库和多线程实现的文件复制程序的示例&#xff1a; 1、问题背景 我们有…

Mac上的最佳3D建模工具-犀牛Rhinoceros 8 for Mac v8.6.24101.05002完美兼容激活

Rhino 8是一款计算机辅助设计&#xff08;CAD&#xff09;和三维建模软件&#xff0c;由美国公司McNeel & Associates开发。它是Rhino系列的最新版本&#xff0c;用于创建、编辑、分析、渲染和动画三维模型。 以下是Rhino 8的一些主要特点和功能&#xff1a; 1. **强大的…