chapter-four/0100~0199/0164.Maximum-Gap

164. Maximum Gap

题目

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

Return 0 if the array contains less than 2 elements.

Example 1:


Input: [3,6,9,1]
Output: 3
Explanation: The sorted form of the array is [1,3,6,9], either
             (3,6) or (6,9) has the maximum difference 3.
             

Example 2:


Input: [10]
Output: 0
Explanation: The array contains less than 2 elements, therefore return 0.

Note:

  • You may assume all elements in the array are non-negative integers and fit in the 32-bit signed integer range.
  • Try to solve it in linear time/space.

题目大意

在数组中找到 2 个数字之间最大的间隔。要求尽量用 O(1) 的时间复杂度和空间复杂度。

解题思路

虽然使用排序算法可以 AC 这道题。先排序,然后依次计算数组中两两数字之间的间隔,找到最大的一个间隔输出即可。

这道题满足要求的做法是基数排序。

代码

package leetcode // 解法一 快排 func maximumGap(nums []int) int { if len(nums) < 2 { return 0 } quickSort164(nums, 0, len(nums)-1) res := 0 for i := 0; i < len(nums)-1; i++ { if (nums[i+1] - nums[i]) > res { res = nums[i+1] - nums[i] } } return res } func partition164(a []int, lo, hi int) int { pivot := a[hi] i := lo - 1 for j := lo; j < hi; j++ { if a[j] < pivot { i++ a[j], a[i] = a[i], a[j] } } a[i+1], a[hi] = a[hi], a[i+1] return i + 1 } func quickSort164(a []int, lo, hi int) { if lo >= hi { return } p := partition164(a, lo, hi) quickSort164(a, lo, p-1) quickSort164(a, p+1, hi) } // 解法二 基数排序 func maximumGap1(nums []int) int { if nums == nil || len(nums) < 2 { return 0 } // m is the maximal number in nums m := nums[0] for i := 1; i < len(nums); i++ { m = max(m, nums[i]) } exp := 1 // 1, 10, 100, 1000 ... R := 10 // 10 digits aux := make([]int, len(nums)) for (m / exp) > 0 { // Go through all digits from LSB to MSB count := make([]int, R) for i := 0; i < len(nums); i++ { count[(nums[i]/exp)%10]++ } for i := 1; i < len(count); i++ { count[i] += count[i-1] } for i := len(nums) - 1; i >= 0; i-- { tmp := count[(nums[i]/exp)%10] tmp-- aux[tmp] = nums[i] count[(nums[i]/exp)%10] = tmp } for i := 0; i < len(nums); i++ { nums[i] = aux[i] } exp *= 10 } maxValue := 0 for i := 1; i < len(aux); i++ { maxValue = max(maxValue, aux[i]-aux[i-1]) } return maxValue } func max(a int, b int) int { if a > b { return a } return b }