Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
0 Star 0 Fork 0

徐云天/leetcode

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
_164.java 1.48 KB
一键复制 编辑 原始数据 按行查看 历史
徐云天 提交于 2021-08-10 11:00 +08:00 . 增加164
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;
}
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Java
1
https://gitee.com/xuyuntian/leetcode.git
git@gitee.com:xuyuntian/leetcode.git
xuyuntian
leetcode
leetcode
master