面试题 16.06. 最小差

154 阅读1分钟

image.png

var smallestDifference = function (a, b) {
    // 先排序
    a.sort((c, d) => c - d);
    b.sort((c, d) => c - d);
    let i = 0, j = 0
    let minDiff = Infinity
    // 移动指针
    while (i < a.length && j < b.length) {
        minDiff = Math.min(minDiff, Math.abs(a[i] - b[j]))
        // a[i] 小于 b[j],说明 a[i] 可能是与 b[j] 相差最小绝对值的数对中的一部分,将 i 指针向右移动,即 i++,以寻找更接近 b[j] 的元素
        if (a[i] < b[j]) {
            i++;
        } else if (a[i] > b[j]) {
            j++;
        }
        // 考虑返回 0 的可能
        else {
            return 0
        }
    }
    return minDiff;
};

面试题 16.06. 最小差 - 力扣(LeetCode)