UVa221 Urban Elevations 细述原理

先讲原理:
我们来个简单的模型(假设下面四个楼房一样高):

一样高的四个楼房

现在我们来想想,如果我们从前向后看,能看到几个楼房?(楼房都一样高)
显然是3号、2号和4号。

那么怎么让计算机解决这个问题呢?
我们判断建筑物是否可见,我们是不是可以枚举从 3号楼最左端到4号楼的最右端 所有的x坐标,看看该建筑物是否在x轴的某个范围内可见,这个在我们人脑中想一下就可以得出答案,但是计算机可不能这样处理问题,因为从 3号楼最右端到4号楼的最左端 的x坐标有无数个,这样一来我们只能将问题 离散化 ,怎么离散化呢?看下图:

这里写图片描述

我们将 3号楼最左端到4号楼的最右端 的区间给分割成6个小区间,这样一来我们就会发现每个区间只有两种状态:1. 存在楼房,2. 不存在楼房。

那么我们怎么知道这个区间内是否存在楼房呢?我们可以在区间中任意取一点,然后判断这点是否属于某栋楼房的范围,这个点我们就可以取中点。

现在我们最后的问题是怎么判断某栋楼是否在某个区间中可见,必须满足下面两个条件:

  1. 建筑物必须包含这个区间(前面讲到,只须判断区间中点是否在建筑物范围内即可)
  2. 建筑物的南面不能有和其处于同一区间并且比其高的建筑物(这个我们只须遍历所有楼房即可)

现在我们来看看怎么通过代码实现这个过程:
先看main()函数:


                
  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值