代码拉取完成,页面将自动刷新
public class _164 {
static class Solution {
public int maximumGap(int[] nums) {
//discuss中的桶排序
if (nums.length <= 1) return 0;
if (nums.length == 2) {
return Math.abs(nums[0] - nums[1]);
}
//n个元素 分布在 [min,max]区间中,它的最大gap>=( max-min) /(n-1)
int max = Integer.MIN_VALUE;
int min = Integer.MAX_VALUE;
for (int val : nums) {
max = Math.max(val, max);
min = Math.min(val, min);
}
int n = nums.length;
int gap = (int) Math.ceil((double) (max - min) / (n - 1));//向上取整
if (gap == 0) return 0;
int size = max / gap + 1;
Integer[] maxNums = new Integer[size];
Integer[] minNums = new Integer[size];
for (int val : nums) {
int idx = val / gap;
maxNums[idx] = maxNums[idx] == null ? val : Math.max(val, maxNums[idx]);
minNums[idx] = minNums[idx] == null ? val : Math.min(val, minNums[idx]);
}
int pre = Integer.MAX_VALUE;
//拿每组最小的减去前个有效组的最大值
for (int i = 0; i < minNums.length; i++) {
if (minNums[i] != null) {
gap = Math.max(gap, minNums[i] - pre);
pre = maxNums[i];
}
}
return gap;
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。