2024.3.27力扣每日一题——统计将重叠区间合并成组的方案数

2024-04-07 16:52

本文主要是介绍2024.3.27力扣每日一题——统计将重叠区间合并成组的方案数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2024.3.27

      • 题目来源
      • 我的题解
        • 方法一 排序+合并区间+快速幂
        • 方法二 官方区间合并

题目来源

力扣每日一题;题序:2580

我的题解

方法一 排序+合并区间+快速幂

先将ranges按第一个元素升序,再按第二个元素升序。然后采用合并区间的方式进行区间合并,每次有区间合并n都减1,最后计算 2 n 2^n 2n%1000000007就可以得到最终的答案。但是由于n可能很大,所以直接计算 2 n 2^n 2n会出现long类型溢出,所以需要再计算过程中一直mod,即如fastPow函数。

时间复杂度:O(nlogn)。主要是排序消耗的时间
空间复杂度:O(logn)。排序所用的栈空间为 O(log⁡n)。

public  int countWays(int[][] ranges) {Arrays.sort(ranges,(a,b)->{if(a[0]==b[0])return a[1]-b[1];elsereturn a[0]-b[0];});int n=ranges.length;int mod=1000000007;int sz=n;int min=ranges[0][0];int max=ranges[0][1];for(int i=1;i<sz;i++){int[] t=ranges[i];if((t[0]>=min&&t[0]<=max)||(t[1]>=min&&t[1]<=max)){n--;min=Math.min(min,t[0]);max= Math.max(max,t[1]);}else{min=t[0];max=t[1];}}long res=fastPow(2,n,mod);return (int)(res%mod);}public   long fastPow(int x,int n,int mod){long res = 1;while(n>0){if((n&1)==1){res=(res*x)%mod;}x=(int)((long)x*x%mod);n>>=1;}return res;}
方法二 官方区间合并

参考官方题解

时间复杂度:O(nlogn)
空间复杂度:O(logn)

static final int MOD = 1000000007;public int countWays(int[][] ranges) {Arrays.sort(ranges, (a, b) -> a[0] - b[0]);int n = ranges.length;int res = 1;for (int i = 0; i < n; ) {int r = ranges[i][1];int j = i + 1;while (j < n && ranges[j][0] <= r) {r = Math.max(r, ranges[j][1]);j++;}res = res * 2 % MOD;i = j;}return res;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

这篇关于2024.3.27力扣每日一题——统计将重叠区间合并成组的方案数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

MySQL进行分片合并的实现步骤

《MySQL进行分片合并的实现步骤》分片合并是指在分布式数据库系统中,将不同分片上的查询结果进行整合,以获得完整的查询结果,下面就来具体介绍一下,感兴趣的可以了解一下... 目录环境准备项目依赖数据源配置分片上下文分片查询和合并代码实现1. 查询单条记录2. 跨分片查询和合并测试结论分片合并(Shardin

MySQL容灾备份的实现方案

《MySQL容灾备份的实现方案》进行MySQL的容灾备份是确保数据安全和业务连续性的关键步骤,容灾备份可以分为本地备份和远程备份,主要包括逻辑备份和物理备份两种方式,下面就来具体介绍一下... 目录一、逻辑备份1. 使用mysqldump进行逻辑备份1.1 全库备份1.2 单库备份1.3 单表备份2. 恢复