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.
Credits:Special thanks to @porker2008 for adding this problem and creating all test cases.
public class Solution {
public int maximumGap(int[] nums) {
if (nums == null || nums.length < 2) return 0;
int max = nums[0];
int min = nums[0];
for (int i = 1; i < nums.length; i++) {
if (max < nums[i]) {
max = nums[i];
}
if (min > nums[i]) {
min = nums[i];
}
}
int bucketSize = (max - min) / (nums.length) + 1;
int[] bucketsMax = new int[nums.length + 1];
int[] bucketsMin = new int[nums.length + 1];
for (int i = 0; i < nums.length + 1; i++) {
bucketsMax[i] = -1;
bucketsMin[i] = -1;
}
for (int num : nums) {
int index = (num - min) / bucketSize;
if (bucketsMax[index] < num) bucketsMax[index] = num;
if (bucketsMin[index] != -1) {
if (bucketsMin[index] > num) {
bucketsMin[index] = num;
}
} else {
bucketsMin[index] = num;
}
}
int preMax = bucketsMax[0];
int maxGap = 0;
for (int i = 1; i <= nums.length; i++) {
if (preMax != -1) {
maxGap = bucketsMin[i] - preMax > maxGap ? bucketsMin[i] - preMax : maxGap;
}
if (bucketsMax[i] != -1) {
preMax = bucketsMax[i];
}
}
return maxGap;
}
}