首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >程序员面试金典 - 面试题 16.06. 最小差(排序+双指针)

程序员面试金典 - 面试题 16.06. 最小差(排序+双指针)

作者头像
Michael阿明
发布2020-07-13 15:48:01
发布2020-07-13 15:48:01
30500
代码可运行
举报
运行总次数:0
代码可运行

1. 题目

给定两个整数数组a和b,计算具有最小差绝对值的一对数值(每个数组中取一个值),并返回该对数值的差

代码语言:javascript
代码运行次数:0
运行
复制
示例:
输入:{1, 3, 15, 11, 2}, {23, 127, 235, 19, 8}
输出: 3,即数值对(11, 8)

提示:
1 <= a.length, b.length <= 100000
-2147483648 <= a[i], b[i] <= 2147483647
正确结果在区间[-2147483648, 2147483647]内

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/smallest-difference-lcci 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 排序后,相互追逐,找最小的差值
代码语言:javascript
代码运行次数:0
运行
复制
class Solution {
public:
    int smallestDifference(vector<int>& a, vector<int>& b) {
    	sort(a.begin(), a.end());
    	sort(b.begin(), b.end());
    	if(a.back() <= b.front())
    		return b.front()-a.back();
    	if(b.back() <= a.front())
    		return a.front()-b.back();
    	int i = 0, j = 0, na = a.size(), nb = b.size(),mindis = INT_MAX;
        long diff;
    	while(i < na && j < nb)
    	{
            diff = a[i]-b[j];
            if(diff <= INT_MAX && diff > INT_MIN) 
                mindis = min(mindis, abs((int)diff));
    		if(a[i] <= b[j])
    			i++;//a小,a往后走,找大的,缩小差距
    		else
    			j++;//b小,b往后找大的
    	}
    	return mindis;
    }
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/03/27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目
  • 2. 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档