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;
};