zoukankan      html  css  js  c++  java
  • [leedcode] Maximum Gap

    题目:(Sort)

    Given an unsorted array, find the maximum difference between the successive elements in its sorted form.

    Try to solve it in linear time/space.

    Return 0 if the array contains less than 2 elements.

    You may assume all elements in the array are non-negative integers and fit in the 32-bit signed integer range.

    题解:

    桶排序!!

    public class Solution {
        public int maximumGap(int[] num) {
            if(num==null||num.length<2)
               return 0;
               
            int min=num[0];
            int max=num[0];
            
            for(int i:num)
            {
               min= Math.min(min,i);
               max= Math.max(max,i);
            }
            
            int gap = (int)Math.ceil((double)(max-min)/(num.length-1));
            int [] bucketMin = new int [num.length-1];
            int [] bucketMax = new int [num.length-1];
            
            Arrays.fill(bucketMin, Integer.MAX_VALUE);
            Arrays.fill(bucketMax, Integer.MIN_VALUE);
            
            for(int i:num)
            {
                if(i==min||i==max)
                  continue;
                  
                int index = (i-min)/gap ;
                bucketMin[index] = Math.min(i,bucketMin[index]);
                bucketMax[index] = Math.max(i,bucketMax[index]);
            }
            
            int prev =min;
            int maxGap = Integer.MIN_VALUE;
            for(int i=0 ; i<num.length-1; i++)
            {
                if(bucketMin[i]==Integer.MAX_VALUE||bucketMax[i]==Integer.MIN_VALUE)
                   continue ;
                
                maxGap=Math.max(bucketMin[i]-prev,maxGap);
                prev=bucketMax[i];
            }
            
            maxGap = Math.max(max-prev,maxGap);
            return maxGap;
        }
    }
  • 相关阅读:
    npm私服包管理-发布
    搭建npm私服
    vue.js框架搭建
    基于cropper实现图片上传,剪切,下载
    base64转图片
    获取file的路径
    如何制定好测试策略(一)
    让测试团队慢慢死去!-有同感,转载
    2016-2016自动化测试的趋势
    2016-安全性测试
  • 原文地址:https://www.cnblogs.com/fengmangZoo/p/4192746.html
Copyright © 2011-2022 走看看