当前位置: 首页 > 编程日记 > 正文

一条直线上N个线段所覆盖的总长度

转自http://blog.csdn.net/bxyill/article/details/8962832

问题描述:

现有一直线,从原点到无穷大。

这条直线上有N个线段。线段可能相交。

问,N个线段总共覆盖了多长?(重复覆盖的地区只计算一次)

================================================

解题思路:

可以将每个线段拆分成“单位1”

遍历所有线段,使用一个数组记录每个线段所走过的“单位1”

最后统计数组中被走过的中“单位1”的个数,即是所有线段覆盖的总长度了。

这里有个问题?数组的大小如何确定?

数组的大小应该是所有线段中最大的端点坐标。

===============================================

顺便想到一个问题。

给出若干个线段。求一共有几个“连通域”。就是将能合并的线段 合并成一个线段。

最后能合并出几个来?

利用上面的思想。非常简单。

只需遍历单位数组的时候做个开始和结尾的记录就行了。

程序实现如下。

===============================================

//此题要求
//求出一条直线上所有线段所覆盖的全程长度是多少。
//重叠的地方只计算一次。
//================================
//本算法的思想是,将每个线段进行像素化,
//添加到一个单位数组c[N]中
//遍历c数组判断哪些单位被覆盖到了,
//在count计数一下就知道一共覆盖了多少路程。
//真是巧妙啊。
//==============================
#include <iostream>
using namespace std;
const int N = 10000;
//线段结构体
struct Segment
{int start;int end;
};
//
int coverage(Segment *segments, int n)
{bool c[N]={false};//每个“单位1”是否被覆盖到int start=0;int end = 0;//遍历n个线段for(int i = 0; i < n; i++){for(int j = segments[i].start; j < segments[i].end; j++){c[j] = true;}//寻找最右端if(segments[i].end > end){end = segments[i].end;}//寻找最左端if(segments[i].start < start){start = segments[i].start;}}//从最左端开始到最右端。遍历单位数组Cint count = 0;for(int i= start; i < end; i++){if(c[i]){int s=i;while(c[i]){count++;i++;}int e=i;cout << "["<<s<<","<<e<<"]"<<endl;}}return count;
};int main()
{Segment s1;s1.start = 1;s1.end = 3;Segment s2;s2.start = 2;s2.end = 6;Segment s3;s3.start = 11;s3.end = 12;Segment s4;s4.start = 10;s4.end = 13;Segment ss[] = {s1,s2,s3,s4};cout << "归并后"<<endl;cout <<"被覆盖总长度:" <<coverage(ss, sizeof(ss)/sizeof(ss[0]))<<endl;
}

输出结果如下:

归并后
[1,6]
[10,13]

被覆盖总长度
8

请按任意键继续. . .

转载于:https://www.cnblogs.com/bethunebtj/articles/4884893.html

相关文章:

html根据字段制作曲线图,canvas制作简单的HTML图表,折线或者矩形统计(原创)

插件描述&#xff1a;canvas制作简单的HTML图表&#xff0c;折线或者矩形统计 使用canvas制作简单的HTML图表&#xff0c;折线或者矩形统计。使用canvas制作简单的HTML图表&#xff0c;折线或者矩形统计&#xff0c;简单而实用。图形由 Ctable类创建&#xff0c;类我已经写好了…

联合索引最左匹配原则成因

使用col3,col2,col1 顺序建立联合索引&#xff0c;通过col3的值建立一个btree &#xff0c;通过关键值去查找“Alice”&#xff0c;在叶子节点中找到两个“Alice”,那么“Alice”对于col2、col1对应的值&#xff0c;那么会对col2&#xff0c;col1分别进行一个有序的排列&#x…

二 IOC之PropertyPlaceholderConfigurer

2019独角兽企业重金招聘Python工程师标准>>> 老长一段时间没有看文档了&#xff0c;今天看到这个PropertyPlaceholderConfigurer有点意思&#xff0c;我于百忙之中抽出点时间&#xff0c;将这个点记录在这里&#xff0c;方便日后慢慢完善&#xff0c;慢慢深入。 因为…

关于Linux服务器磁盘空间占满问题的解决方法

下面给大家分享一篇关于Linux服务器磁盘占满问题解决方法&#xff08;/dev/sda3 满了&#xff09;&#xff0c;需要的的朋友参考下吧下面我们一起来看一篇关于Linux服务器磁盘占满问题解决&#xff08;/dev/sda3 满了&#xff09;&#xff0c;希望碰到此类问题的人能带来帮助。…

Maya人物角色行走动画制作视频教程

Maya人物角色行走动画制作视频教程 Maya人物角色行走动画制作视频教程 持续时间2h 57m 包含项目文件 1920X1080 MP4 大小解压后&#xff1a;2.27G 标题:技能分享–在Maya制作专业行走动画 云桥网络 平台 huo取 教程 信息: 这门课程是为初学者设计的&#xff0c;他们理解工作…

细数技术指标-[转载]

技术指标类别庞杂&#xff0c;要一一学全&#xff0c;基本不可能&#xff0c;也没有这个必要。我们只要掌握几个常用的指标&#xff0c;了解它们的原理&#xff0c;从而举一反三&#xff0c;就足够了。其实任何一种技术指标都是从形态、价格、量、时间这四项出发的&#xff0c;…

html无序列表的滚动效果,html无序列表标签和有序列表标签使用示例

原标题&#xff1a;html无序列表标签和有序列表标签使用示例一、上下层列表标签:&#xff1a;上层dt下层dd&#xff1a;封装的内容会被自动缩进的效果复制代码代码如下:运动户外板鞋篮球鞋足球鞋跑步鞋二、定义有序列表: 属性&#xff1a;type&#xff1a; 可以设置排序的样式 …

2022-2028年中国微藻行业市场调查研究及前瞻分析报告

【报告类型】产业研究 【报告价格】4500起 【出版时间】即时更新&#xff08;交付时间约3个工作日&#xff09; 【发布机构】智研瞻产业研究院 【报告格式】PDF版 本报告介绍了中国微藻行业市场行业相关概述、中国微藻行业市场行业运行环境、分析了中国微藻行业市场行业的…

cocos2dx 优化略记

缓存cache: 预加载资源到内存, 可以异步加载. 直接使用sprite:create()来加载资源的话, 有时候会发现, 在第一次运行动作的时候会变的很卡. 那是因为第一次要加载资源到内存, 加载资源到内存这个过程会比较的慢. 资源较大的话, 明显的会感觉到卡帧 批次渲染: 100个相同的…

关于AD编程的一些资料

有人问我怎样在.NET下操作AD对象&#xff0c;找了些资料和Sample&#xff0c;留作备用。 .NET Framework Class Library: System.DirectoryServices Namespace http://msdn.microsoft.com/library/en-us/cpref/html/frlrfsystemdirectoryservices.asp How to poll for changes …

Blender和Substance Painter制作科幻装甲视频教程

Blender和Substance Painter制作科幻装甲视频教程 时长7小时 1280X720 MP4 题目&#xff1a;《技能共享》--用Blender和Substance Painter绘制科幻盔甲 流派:电子学习| MP4 |视频:h264&#xff0c;1280x720 |音频:AAC&#xff0c;48.0 KHz 语言&#xff1a;英语中英文字幕&…

Linux wait() 和 waitpid()函数介绍

转载自http://blog.csdn.net/wallwind/article/details/6998602 当一个进程正常或异常终止的时候&#xff0c;内核就像其父进程发送SIGCHLD信号&#xff0c;因为子进程是个一步事件&#xff0c;所以这种信号也是内核系那个父进程发的异步通知。父进程可以选择忽略该信号&#x…

jq修改iframe html代码,jQuery控制iFrame(实例代码)

用jquery在IFRAME里取得父窗口的某个元素的值只好用DOM方法与jquery方法结合的方式实现了1.在父窗口中操作 选中IFRAME中的所有单选钮$(window.frames["iframe1"].document).find(”input[typeradio]“).attr(”checked”,”true”);2.在IFRAME中操作 选中父窗口中的…

索引是建的越多越好吗?

索引是建的越多越好吗&#xff1f; 明显不是&#xff0c;有以下几点&#xff1a; 数据量小的表不需要建立索引&#xff0c;建立会增加额外的索引开销不经常引用的列不要建立索引&#xff0c;因为不常用&#xff0c;即使建立了索引也没有多大意义。对经常用于查询的字段应该创…

TFS数据迁移之sync_by_blk

本文档记录了两套tfs 2.2.16系统之间的数据迁移过程。Source环境介绍&#xff1a;Tfs 主nameserver: 192.168.1.225/24 (vip 229)Tfs 从nameserver: 192.168.1.226/24 Tfs data server 1: 192.168.1.226/24 &#xff08;启动三个挂载点,每个挂载点分配20G空间&#xff09;Tfs …

阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第5节 final关键字_5_final关键字用于修饰成员变量...

直接这么修饰成员变量就会报错。这里必须要手动赋值&#xff0c;因为string name这里的默认是值null。一但默认值以后就不能后续再赋值了。所以这里强制你必须要手动赋值。 给name赋值后。后面所有的代码 尝试给name赋值的地方都报错了。 通过构造进行赋值。 构造有两个一个有参…

Blender 和Unreal Engine中的模块化3D建筑技能学习视频教程

Blender 和Unreal Engine中的模块化3D建筑技能学习视频教程 流派:电子学习| MP4 |视频:h264&#xff0c;1280720 |音频:AAC&#xff0c;48.0 KHz 语言&#xff1a;英语中英文字幕&#xff08;根据原英文字幕翻译更准确&#xff09; |大小解压后:3.17 GB |时长:5h 42m 用Blen…

$().html()对ie9无效,不注意这点,\9和\0就可能对hack IE11\IE9\IE8无效

每次设计一张网页或一个表单&#xff0c;都被各种浏览器的兼容问题伤透脑筋&#xff0c;尤其是IE家族。在做兼容性设计时&#xff0c;我们往往会使用各种浏览器能识别的独特语法进行hack&#xff0c;从而达到各种浏览器下显示正常的目的。其中&#xff0c;我们用得最多莫属于\9…

MPC8313ERDB不新鲜pkg包裹,把文件放进Ramdisk

MPC8313ERDB不新鲜pkg包裹&#xff0c;把文件放进Ramdisk 经ltib编译器生成rootfs.ext2.gz.uboot它可以直接uboot采用。假设我们编写了相应的外部文件把Ramdisk往里走。您可以创建一个pkg包裹。然后配置编译&#xff08;&#xff0c;。&#xff0c;&#xff09;。当然这样的方法…

2022-2028年中国微型汽车市场投资分析及前景预测报告

【报告类型】产业研究 【报告价格】4500起 【出版时间】即时更新&#xff08;交付时间约3个工作日&#xff09; 【发布机构】智研瞻产业研究院 【报告格式】PDF版 本报告介绍了中国微型汽车行业市场行业相关概述、中国微型汽车行业市场行业运行环境、分析了中国微型汽车行…

[Python]小百合十大爬虫

国庆几天在家看了几篇关于使用Python来编写网络爬虫的博客&#xff0c;想来自己断断续续学习Python也有几个月了&#xff0c;但一个像样的程序都没有写过&#xff0c;编程能力并没有得到提高&#xff0c;愧对自己花费的时间。很多时候虽然知道什么事情是对的&#xff0c;但自身…

Web自动化测试 六 ----- selector选择

1、一般情况下都是先定位元素在选择 from selenium.webdriver import Chrome from selenium.webdriver.support.wait import WebDriverWait from selenium.webdriver.common.by import By from selenium.webdriver.support import expected_conditions as ECdriver Chrome()dr…

AI矢量绘图软件技能学习视频教程

AI矢量绘图软件技能学习视频教程 技能分享——Adobe Illustrator CC——精粹大师班 云桥网络 平台 获取 教程 时长:5h 42m |视频:。MKV 1280720&#xff0c;30 fps(r) |音频:AAC&#xff0c;44100 Hz&#xff0c;2ch |大小解压后:2.27 GB 语言&#xff1a;英语中英文字幕&am…

利用JS判断是手机端还是PC端 浏览网站

引入百度JS&#xff1a; <script src"http://siteapp.baidu.com/static/webappservice/uaredirect.js" type"text/javascript"></script> <script type"text/javascript">uaredirect("这里写跳转手机端网页地址");&…

职校中的计算机学的是什么,职校计算机专业主要学什么课

职校计算机专业主要学什么课2020-11-19 15:37:41文/樊越很多同学都知道计算机是近几年的大热门课程&#xff0c;小编整理了一些计算机专业的课程&#xff0c;大家一起来看看吧。计算机专业课程学习计算机的基本原理、基本结构、基本算法、基本设计等。主课程&#xff1a;计算机…

浅谈MySQL存储引擎-InnoDBMyISAM

浅谈MySQL存储引擎-InnoDB&MyISAM 存储引擎在MySQL的逻辑架构中位于第三层&#xff0c;负责MySQL中的数据的存储和提取。MySQL存储引擎有很多&#xff0c;不同的存储引擎保存数据和索引的方式是不同的。每一种存储引擎都有它的优势和劣势&#xff0c;本文只讨论最常见的In…

android ValueAnimator学习

2019独角兽企业重金招聘Python工程师标准>>> 一、简介 This class provides a simple timing engine for running animations which calculate animated values and set them on target objects. There is a single timing pulse that all animations use. It runs …

Annotation

在进行类或方法定义的时候&#xff0c;都可以使用一系列的Annotation&#xff08;public interface Annotation&#xff09;进行声明&#xff0c;如果想要获取这些Annotation的信息&#xff0c;可以直接通过反射来完成。在 java.lang.reflect 里面有一个AccessibleObject类&…

GSG灰猩猩插件合集包

GSG灰猩猩插件合集包 GSG灰度大猩猩Plus中心插件HDRI和材料2021年 大小&#xff1a;59G 信息: 云桥网络 平台获取素材 这是最新的(截至2021年4月29日)GSG Plus HUB&#xff0c;包括Plus订阅的所有插件、材料和HDRIs。 支持c4d版本:R23、S24(仅限Windows) 该包包含最新的GS…

百度地图JavaScript API自定义覆盖物、自定义信息窗口增删时的显示问题

项目中&#xff0c;需求&#xff1a;在百度地图上实时画出车辆&#xff0c;并能点击车辆弹出信息框查看实时信息。 实现&#xff1a;通过不停的画覆盖物并删除掉。点击覆盖物时弹出信息窗口。 问题&#xff1a;删除掉覆盖物后信息窗也删除掉了。因为信息窗是建立在覆盖物的基础…