LeetCode - 164 最大间距

在这里插入图片描述
桶排序
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

class Solution {
    public int maximumGap(int[] nums) {
         int n = nums.length;
         if(n < 2)//数组元素个数小于2 直接返回0
           return 0;
         //求数组元素最大值 最小值
         int max = Integer.MIN_VALUE;
         int min = Integer.MAX_VALUE;
         for(int i = 0;i < n;i++){
             max = Math.max(nums[i],max);
             min = Math.min(min,nums[i]);
         }
         // 桶的大小
         int bucketSize = Math.max((max-min) / (n-1),1);
         //桶的数目
         int bucketNum = (max-min)/bucketSize + 1;
         //记录每个桶的最大值和最小值就好
         int[][] bucket = new int[bucketNum][2];
         //初始化桶 bucket[i][0] 存放第i个桶的最小值 bucket[i][1] 存放第i个桶的最大值
         for(int i = 0; i < bucketNum;i++){
             bucket[i][0] = Integer.MAX_VALUE;
             bucket[i][1] = Integer.MIN_VALUE;
         }
         //将nums中的每个数相应的放入桶中
         //index = (nums[i] - min) / bucketSize
         for(int i = 0; i< n;i++){
             int index = (nums[i] - min) / bucketSize;
             bucket[index][0] = Math.min(bucket[index][0],nums[i]);
             bucket[index][1] = Math.max(bucket[index][1],nums[i]);
         }
         int ans = 0;
         int prevmax = Integer.MIN_VALUE;
         for(int i = 0; i < bucketNum;i++){
             //该桶不为空 且 该桶之前有不为空的桶
             if(prevmax != Integer.MIN_VALUE && bucket[i][0] != Integer.MAX_VALUE)
             {
                 ans = Math.max(ans,bucket[i][0] - prevmax);
             }
             if(bucket[i][1] != Integer.MIN_VALUE){
                prevmax = bucket[i][1];
             }
         }
         return ans;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值