题目描述:

Winter is coming! Your first job during the contest is to design a standard heater with fixed warm radius to warm all the houses.

Now, you are given positions of houses and heaters on a horizontal line, find out minimum radius of heaters so that all houses could be covered by those heaters.

So, your input will be the positions of houses and heaters seperately, and your expected output will be the minimum radius standard of heaters.

Note:

  1. Numbers of houses and heaters you are given are non-negative and will not exceed 25000.
  2. Positions of houses and heaters you are given are non-negative and will not exceed 10^9.
  3. As long as a house is in the heaters' warm radius range, it can be warmed.
  4. All the heaters follow your radius standard and the warm radius will the same.

Example 1:

Input: [1,2,3],[2]
Output: 1
Explanation: The only heater was placed in the position 2, and if we use the radius 1 standard, then all the houses can be warmed.

Example 2:

Input: [1,2,3,4],[1,4]
Output: 1
Explanation: The two heater was placed in the position 1 and 4. We need to use radius 1 standard, then all the houses can be warmed.

要完成的函数:

int findRadius(vector<int>& houses, vector<int>& heaters)

说明:

1、这道题目给定两个vector,一个存储了房屋的位置,另一个存储了加热器的位置,要求输出加热器的最小半径,使得加热器可以覆盖所有房子。房屋和加热器都是一维水平向量。

2、假设房屋位置和加热器位置如下:(三角形代表房子,圆形代表加热器)

△△△△△△△△△△△△

○             ○         ○

那么我们最直接的想法就是找到房子两边的上下两个加热器,比如第3个房子就找第1和第2个加热器,第8个房子就找第2和第3个加热器,然后看这两个加热器哪个距离它更近。

把最小距离存储起来,里面最大的那个数值就是我们要的最小半径。

那么如何找到房子两边的上下两个加热器呢?用二分查找,好像有点慢。

我们可以这样做:

第一次对房子和加热器做循环,从左边开始,找到大于等于房子位置的加热器,加热器位置减去房子位置,得到距离,这是上加热器跟房子的距离。

第二次对房子和加热器做循环,从右边开始,找到小于房子位置的加热器,房子位置减去加热器位置,得到距离,这是下加热器跟房子的距离。

经过两次循环,一次上限减房子位置,一次房子位置减下限,我们就可以直接得到距离。

代码如下:

    int findRadius(vector<int>& houses, vector<int>& heaters)
{
sort(houses.begin(),houses.end());//排序
sort(heaters.begin(),heaters.end());
int s1=houses.size(),s2=heaters.size(),max1=;//max1用在最后,存储最大数值
vector<int> res(s1,INT_MAX);//初始值为INT_MAX
for(int i=,h=;i<s1&&h<s2;)//上限-房子位置
{
if(heaters[h]>=houses[i])
{
res[i]=heaters[h]-houses[i];
i++;
}
else
h++;
}
for(int i=s1-,h=s2-;i>=&&h>=;)//房子位置-下限,跟原本数值比较,存储小的值
{
if(heaters[h]<houses[i])
{
res[i]=min(houses[i]-heaters[h],res[i]);
i--;
}
else
h--;
}
for(int i=;i<s1;i++)
{
if(res[i]>max1)
max1=res[i];
}
return max1;
}

上述代码实测73ms,beats 90.81% of cpp submissions。

leetcode-475-Heaters的更多相关文章

  1. 【leetcode】475. Heaters

    problem 475. Heaters solution1: class Solution { public: int findRadius(vector<int>& house ...

  2. [Leetcode] Binary search -- 475. Heaters

    Winter is coming! Your first job during the contest is to design a standard heater with fixed warm r ...

  3. 【LeetCode】475. Heaters 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 遍历 日期 题目地址:https://leetcod ...

  4. 475 Heaters 加热器

    详见:https://leetcode.com/problems/heaters/description/ C++: class Solution { public: int findRadius(v ...

  5. Java实现 LeetCode 475 供暖器

    475. 供暖器 冬季已经来临. 你的任务是设计一个有固定加热半径的供暖器向所有房屋供暖. 现在,给出位于一条水平线上的房屋和供暖器的位置,找到可以覆盖所有房屋的最小加热半径. 所以,你的输入将会是房 ...

  6. 475. Heaters

    static int wing=[]() { std::ios::sync_with_stdio(false); cin.tie(NULL); ; }(); class Solution { publ ...

  7. 475. Heaters (start binary search, appplication for binary search)

    Winter is coming! Your first job during the contest is to design a standard heater with fixed warm r ...

  8. 475. Heaters 加热范围

    [抄题]: Winter is coming! Your first job during the contest is to design a standard heater with fixed ...

  9. Leetcode 475.供暖气

    供暖气 冬季已经来临. 你的任务是设计一个有固定加热半径的供暖器向所有房屋供暖. 现在,给出位于一条水平线上的房屋和供暖器的位置,找到可以覆盖所有房屋的最小加热半径. 所以,你的输入将会是房屋和供暖器 ...

  10. 【leetcode】Heaters

    Winter is coming! Your first job during the contest is to design a standard heater with fixed warm r ...

随机推荐

  1. 怎样取得selected的option选项的value值

    现在有一id=test的下拉框,怎么拿到选中的那个值呢?   分别使用javascript原生的方法和jquery方法   <select id="test"  name=& ...

  2. RTX二次开发::检索 COM 类工厂中 CLSID 为 {79210E58-99EB-45D0-8890-763EFEAA143F} 的组件失败,

    解决方法: 1.Interop.RTXSAPILib.dll这个是32位的 将IIS 应用程序池 启用32位应用程序 设置为true就可以了, 2.把编译好的程序选择X86平台运行,就好了 程序员的基 ...

  3. Halcon中一些突然想不起来但确实有用的算子

    1.Develop dev_display  在现有图形窗口中显示图像目标. dev_set_color   设置一个或更多输出颜色,通常用于设置region或者xld的颜色. dev_set_dra ...

  4. VS2017与Qt5.7.0(静态库)环境基本配置

    **************************************************************************************************** ...

  5. 下拉菜单--JavaScript触发方法

    1. $(function(){ $(".dropdown-toggle").one("click",function(){ $(this).dropdown( ...

  6. Ubuntu14.04-LTS 从系统安装到配置可用

    1.安装Ubuntu14.04LTS-64bit 使用U盘安装很方便快捷,可以使用老毛桃使用iso模式制作一个U盘启动盘,然后分区安装. 如果使用硬盘安装的话需要注意的问题是: 如果电脑上以前有Lin ...

  7. Python实现二叉树的遍历

    二叉树是有限个元素的集合,该集合或者为空.或者有一个称为根节点(root)的元素及两个互不相交的.分别被称为左子树和右子树的二叉树组成. 二叉树的每个结点至多只有二棵子树(不存在度大于2的结点),二叉 ...

  8. [GO]简单的并发服务器

    package main import ( "net" "fmt" "strings" ) func HandleConn(conn net ...

  9. 【转载】Redis优化经验

    转载地址:http://blog.sina.com.cn/s/blog_4be888450100z2ze.html 内存管理优化 Redis Hash是value内部为一个HashMap,如果该Map ...

  10. Actor模型文章收集

    参与者模式——维基百科 Akka.Net——github开源项目 Actor原理——比较深入的文章