java实现合并多个线段,计算多个线段的实际覆盖长度_java 多条线段合并为一条线-程序员宅基地

技术标签: 算法  

算法: 计算多个线段实际覆盖的长度。
例如:
线段组1:{ {1, 2}, {2, 3}, {3, 5}, {4, 10.5}, {11, 13}}的长度为
[1,10.5],[11,13]的长度为11.5;

线段组2:{ {1, 5}, {4, 5}, {0.7, 6}, {0.9, 1.5}}的长度为[0.7,6]的长度为5.3;

思路分析:
1.由题意知道: 要求实际长度,凡是两个线段有重叠的地方我们都需要合并
2.这里采用双重遍历分别拿数组的第1个值跟第二个比较,拿线段组1举例,
第一次是用{1,2},{2,3}比较,发现重叠线段,合并成{1,3}。此时线段组1{ {1, 3}, {3, 5}, {4, 10.5}, {11, 13}}
3.重置循环,第二次拿{1, 3}, {3, 5}比较,合并成{1,5}。以此类推,最终合并后的线段组1{ {1,10.5},{11,13}}
4.遍历线段组1并累加求和输出结果: 11.5

那么代码片如下:

   public static double coverageLength(double[][] nums) {
   
    
        List<double[]> list = new LinkedList<>();
        for (int i = 0; i < nums.length; i++) {
   
    
            list.add(nums[i]);
        }

        for (int i = 0; i < list.size(); i++) {
   
    
            for (int j = i + 1; j < list.size(); j++
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_41788067/article/details/104059001

智能推荐

CRC冗余校验码及查表法_crc4错误概率-程序员宅基地

文章浏览阅读987次。CRC冗余校验码及查表法什么是CRC编码它将一个长度为k的位串看作是系数是0或者1的k-1次多项式使用一个长度为r+1的生成多项式进行模2计算,生成一个长度为r的字符序列,能检测长度小于等于r的所有突发错误,当突发错误长度为r+1时,只有其刚刚好等于生成多项式,才检测不出来。多项式的最高位、最低位系数必须为1(我不知道为什么)计算方法:(此处使用的减法是模2减法,不进位不借位,相当于XOR运算)例如:使用G(x)=11001检测位串1011011010110110000011001----_crc4错误概率

STM32+ESP8266+DHT11通过MQTT协议连接新版ONENET云平台上传数据_新版onenet连接stm32-程序员宅基地

文章浏览阅读5.7k次,点赞9次,收藏119次。前段时间ONENET云平台进行了升级更新,此前平台的多协议接入(包含旧版MQTT、HTTP、EDP、Modbus、TCP透传等)接口已经隐藏,后续应该会下架,为了能够后续继续使用ONENET云平台,就需要学会使用将数据上传到新版ONENET云平台。经过一段时间的摸索,现在可以成功将数据上传。此次使用MQTT协议将温湿度通过ESP8266_WIFI模块上传到新版ONENET云平台,并使用app.wxbit.com图形化APP制作工具制作APP调用ONENET云平台提供的API接口实时显示温湿度数据。_新版onenet连接stm32

百度网盘直接解析高速下载文件源码_百度网盘解析-程序员宅基地

文章浏览阅读5.6k次。介绍:百度网盘直接高速下载文件源码上传源码 访问域名跳转安装页面填写相关信息 安装完成源码功能:通过curl获取网盘文件信息,处理后显示在网页中。通过api接口以及SVIP账号的Cookie(BDUSS)获取高速下载链接。网盘下载地址:http://kekewl.cc/yk09TgCFisr0图片:..._百度网盘解析

python采集人脸_Python+Dlib+Opencv实现人脸采集并表情判别功能的代码-程序员宅基地

文章浏览阅读525次。一、dlib以及opencv-python库安装介于我使用的是jupyter notebook,所以在安装dlib和opencv-python时是在这个命令行安装的dlib安装方法:1.若可以,直接使用上图所示命令行输入以下命令:pip install cmakepip install boostpip install dlib若安装了visual studio2019应该就可以直接pip ins..._python 采集人脸图像的代码

图表——SM2密钥协商与ECMQV对比-程序员宅基地

文章浏览阅读4.9w次,点赞3次,收藏7次。1. SM2密钥协商流程图2.SM2密钥协商与ECMQV对比1995年,Menezes等人给出MQV方案,该方案与SM2方案仅在少量几个地方有差异:紫色高亮的部分为SM2方案特有。 青色高亮的部分为MQV方案特有。..._ecmqv

台式计算机显卡驱动位置,台式电脑独立显卡怎么安装驱动的-程序员宅基地

文章浏览阅读1.4k次。想要使用台式电脑玩游戏,那么安装一块性能足够强劲的显卡是非常有必要的,很多朋友在购买台式电脑的时候,可能因为各种各样的原因没有安装独立显卡,所以一直都使用集成显卡,但因为在网上购买独立显卡又非常的便宜,所以想要自己动手安装显卡,那么在安装了显卡之后应当怎样安装驱动呢?下面我们来给大家详细的介绍一下这个问题。1、台式电脑独立显卡在安装成功,开机之后需要安装相应的显卡驱动,才能够让独立显卡正常的工作。..._显卡怎么驱动

随便推点

2020年中南大学研究生招生夏令营机试题_中南大学 计算机 夏令营 笔试-程序员宅基地

文章浏览阅读804次。2020年中南大学研究生招生夏令营机试题题目链接A题题目描述众所周知,彩虹有7种颜色,我们给定七个 字母和颜色 的映射,如下所示:‘A’ -> “red”‘B’ -> “orange”‘C’ -> “yellow”‘D’ -> “green”‘E’ -> “cyan”‘F’ -> “blue”‘G’ -> “purple”但是在某一..._中南大学 计算机 夏令营 笔试

Cmake的option与cmake_dependent_option-程序员宅基地

文章浏览阅读2.9k次。一、介绍cmake提供了一组内置宏,用户可以自己设置。只有当该集合中的其他条件为真时,该宏才会向用户提供一个选项。语法include(CMakeDependentOption)CMAKE_DEPENDENT_OPTION(USE_FOO "Use Foo" ON "USE_BAR;NOT USE_ZOT" OFF)如果USE_BAR为true而USE_ZOT为false,则提供一个默认为ON的选项USE_FOO。否则,它将USE_FOO设._cmake_dependent_option

C++ =default-程序员宅基地

文章浏览阅读5.2k次,点赞10次,收藏34次。在c++中如果我们自行定义了一个构造函数,那么编译器就不会再次生成默认构造函数,我们先看如下的代码我们定义一个类,这个类没有定义构造函数,此时在下面一段代码依然可以正常使用,我们加上一个自定义构造函数:此时编译器会报错,原因很简单,我们自定义了一个构造函数,以前的默认构造函数没了,我们要用如下的方式调用:如果我们还要使用无参构造函数得在定义时自己写个好了此时不报错了,但是这样写代码执行效率没有编译器生成的自定义函数的效率高,为了解决这个问题,C++11 标准引入了一个新特性:default 函数。程_c++ =default

linux gcc 4.8.2,gcc4.8.2 编译异常-程序员宅基地

文章浏览阅读446次。gcc4.8.2 编译错误 求助checkingfor--enable-version-specific-runtime-libs...nocheckingfor--enable-generated-files-in-srcdir...nocheckingbuildsystemtype...i686-pc-linux-gnucheckinghostsystemtype....._gcc libatomic error

IOS企业版app部署到自己服务器,不通过AppStore,在iOS设备上直接安装应用程序_plist中内嵌的下载地址 带参-程序员宅基地

文章浏览阅读2.7w次。IOS企业版app部署到服务器上说明 正对ios升级得ios7 以后,plist文件必须放到 https得服务器上了,http不可以用了。 解决方式: 找一个第三方https外链的网盘(推荐:七牛云存储https://portal.qiniu.com/),将plist文件放到网盘上,ipa安装包可以放在 自己的服务器上。不通过在AppStore,在IOS设备上直接安_plist中内嵌的下载地址 带参

2024最新UI千月影视APP源码前后端源码搭建教程_影视源码-程序员宅基地

文章浏览阅读967次。3.修改前端 config 文件内的id=”A6168029539364″ 改为你apicloud显示的。1.全部替换 id.omgk.cn为 你的域名 全部替换 千彩视频 为你的名字。3.设置thinkphp伪静态 跨站日志全部关闭 php版本5.6+2.导入数据库 全部替换id.omgk.cn 为 你的域名。4.后台地址:login/login/mike。1.进数据库文件内修改数据库名称用户名密码等。账号:admin密码:admin。要源码的请自行百度:一生相随博客。_影视源码

推荐文章

热门文章

相关标签