Leetcode 164 Solution
This article provides solution to leetcode question 164 (maximum-gap).
Access this page by simply typing in "lcs 164" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/maximum-gap
Solution
class Solution {
public:
int maximumGap(vector<int>& nums) {
if (nums.size() < 2)
return 0;
int min_val = INT_MAX;
int max_val = INT_MIN;
for (auto num : nums)
{
min_val = min(min_val, num);
max_val = max(max_val, num);
}
int bucket_size = max((int)((max_val - min_val) / (nums.size() - 1)), 1);
int bucket_num = (max_val - min_val) / bucket_size + 1;
vector<int> min_buckets(bucket_num, INT_MAX);
vector<int> max_buckets(bucket_num, INT_MIN);
vector<bool> empty_buckets(bucket_num, true);
for (auto num : nums)
{
int i = (num - min_val) / bucket_size;
min_buckets[i] = min(min_buckets[i], num);
max_buckets[i] = max(max_buckets[i], num);
empty_buckets[i] = false;
}
int max_dist = 0;
int pre = 0;
for (int i = 1; i < nums.size(); i++)
{
if (empty_buckets[i])
continue;
max_dist = max(max_dist, min_buckets[i] - max_buckets[pre]);
pre = i;
}
return max_dist;
}
};