算法leetcode|56. 合并区间(rust重拳出击)

2023-10-10 13:50

本文主要是介绍算法leetcode|56. 合并区间(rust重拳出击),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


文章目录

  • 56. 合并区间:
    • 样例 1:
    • 样例 2:
    • 提示:
  • 分析:
  • 题解:
    • rust:
    • go:
    • c++:
    • python:
    • java:


56. 合并区间:

以数组 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

分析:

  • 面对这道算法题目,二当家的再次陷入了沉思。
  • 如果没想到排序是比较麻烦的,而下定决定使用排序也不是那么容易,因为排序本身的时间复杂度也不低,但是对于这个情况来说,还是很值得的。
  • 区间有两个值,应该按照开始值排序,而不是末尾值,当然逆向处理也是可以的,但是违背常理。
  • 根据区间开始值排序,前一个区间的末尾和下一个区间的开始值会出现几种情况:
    1. 前一个区间和后一个区间没有交集,那么当前区间就处理完毕,直接开始处理下一个区间。
    2. 前一个区间和后一个区间有部分重叠,那么就将两个区间合并,然后接着处理下一个区间。
    3. 前一个区间完整包含了后一个区间,那么直接抛弃后一个区间,然后继续处理下一个区间。
  • 后两种情况可以统一认为是有重叠,只需要统一处理为更新当前处理区间的末尾值即可。


题解:

rust:

impl Solution {pub fn merge(mut intervals: Vec<Vec<i32>>) -> Vec<Vec<i32>> {intervals.sort_unstable();let mut ans: Vec<Vec<i32>> = Vec::new();let (mut l, mut r) = (intervals[0][0], intervals[0][1]);intervals.iter().skip(1).for_each(|cur| {if r < cur[0] {// 没重合ans.push(vec![l, r]);l = cur[0];r = cur[1];} else {// 重合r = r.max(cur[1]);}});ans.push(vec![l, r]);return ans;}
}

go:

func merge(intervals [][]int) [][]int {sort.Slice(intervals, func(i, j int) bool {return intervals[i][0] < intervals[j][0]})var ans [][]intlast := intervals[0]for i := 1; i < len(intervals); i++ {cur := intervals[i]if last[1] < cur[0] {// 没有重合ans = append(ans, last)last = cur} else {// 有重合if cur[1] > last[1] {last[1] = cur[1]}}}ans = append(ans, last)return ans
}

c++:

class Solution {
public:vector<vector<int>> merge(vector<vector<int>>& intervals) {sort(intervals.begin(), intervals.end());vector<vector<int>> ans;for (int i = 0; i < intervals.size(); ++i) {const int l = intervals[i][0], r = intervals[i][1];if (ans.empty() || ans.back()[1] < l) {ans.push_back({l, r});} else {ans.back()[1] = max(ans.back()[1], r);}}return ans;}
};

python:

class Solution:def merge(self, intervals: List[List[int]]) -> List[List[int]]:intervals.sort(key=lambda x: x[0])ans = []for interval in intervals:if not ans or ans[-1][1] < interval[0]:# 不重合ans.append(interval)else:# 重合ans[-1][1] = max(ans[-1][1], interval[1])return ans

java:

class Solution {public int[][] merge(int[][] intervals) {Arrays.sort(intervals, Comparator.comparingInt(o -> o[0]));final List<int[]> ans  = new ArrayList<int[]>();int[]             last = intervals[0];for (int i = 1; i < intervals.length; ++i) {final int[] cur = intervals[i];if (last[1] < cur[0]) {// 没重合ans.add(last);last = cur;} else {// 重合last[1] = Math.max(last[1], cur[1]);}}ans.add(last);return ans.toArray(new int[ans.size()][]);}
}

非常感谢你阅读本文~
欢迎【点赞】【收藏】【评论】~
放弃不难,但坚持一定很酷~
希望我们大家都能每天进步一点点~
本文由 二当家的白帽子:https://le-yi.blog.csdn.net/ 博客原创~


这篇关于算法leetcode|56. 合并区间(rust重拳出击)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/180867

相关文章

使用Python创建一个能够筛选文件的PDF合并工具

《使用Python创建一个能够筛选文件的PDF合并工具》这篇文章主要为大家详细介绍了如何使用Python创建一个能够筛选文件的PDF合并工具,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录背景主要功能全部代码代码解析1. 初始化 wx.Frame 窗口2. 创建工具栏3. 创建布局和界面控件4

Rust中的注释使用解读

《Rust中的注释使用解读》本文介绍了Rust中的行注释、块注释和文档注释的使用方法,通过示例展示了如何在实际代码中应用这些注释,以提高代码的可读性和可维护性... 目录Rust 中的注释使用指南1. 行注释示例:行注释2. 块注释示例:块注释3. 文档注释示例:文档注释4. 综合示例总结Rust 中的注释

Rust格式化输出方式总结

《Rust格式化输出方式总结》Rust提供了强大的格式化输出功能,通过std::fmt模块和相关的宏来实现,主要的输出宏包括println!和format!,它们支持多种格式化占位符,如{}、{:?}... 目录Rust格式化输出方式基本的格式化输出格式化占位符Format 特性总结Rust格式化输出方式

Rust中的Drop特性之解读自动化资源清理的魔法

《Rust中的Drop特性之解读自动化资源清理的魔法》Rust通过Drop特性实现了自动清理机制,确保资源在对象超出作用域时自动释放,避免了手动管理资源时可能出现的内存泄漏或双重释放问题,智能指针如B... 目录自动清理机制:Rust 的析构函数提前释放资源:std::mem::drop android的妙

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python自动化办公之合并多个Excel

《Python自动化办公之合并多个Excel》在日常的办公自动化工作中,尤其是处理大量数据时,合并多个Excel表格是一个常见且繁琐的任务,下面小编就来为大家介绍一下如何使用Python轻松实现合... 目录为什么选择 python 自动化目标使用 Python 合并多个 Excel 文件安装所需库示例代码

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P