• 【LeetCode】164. Maximum Gap (2 solutions)


    Maximum Gap

    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.

    解法一:

    先排序O(nlogn),再一次遍历,得到maxGap

    虽然不满足O(n)的时间要求,但是最直观的想法。

    class Solution {
    public:
        int maximumGap(vector<int>& nums) {
            if(nums.empty() || nums.size() == 1)
                return 0;
            sort(nums.begin(), nums.end());
            int ret = 0;
            for(int i = 1; i < nums.size(); i ++)
                ret = max(ret, nums[i]-nums[i-1]);
            return ret;
        }
    };

    解法二:为了满足O(n)复杂度,我尝试了计数排序,但是会TLE。因此使用桶排序来做。

    (计数排序可以看做是桶大小为1的桶排序,但由于桶数目太多导致遍历时间过长。)

    最大gap肯定是出现在后一个有效桶的min与前一个有效桶的max之间。

    “有效”指的是忽略空桶。

    class Solution {
    public:
        int maximumGap(vector<int>& nums) {
            if(nums.empty() || nums.size() == 1)
                return 0;
            int n = nums.size();
            int minAll = *min_element(nums.begin(), nums.end());
            int maxAll = *max_element(nums.begin(), nums.end());
            // type conversion!!!
            double gap = ((double)(maxAll - minAll)) / (n - 1);
            // compute min and max element for each bucket
            vector<int> minV(n-1, INT_MAX);
            vector<int> maxV(n-1, INT_MIN);
            for(int i = 0; i < n; i ++)
            {
                if(nums[i] != maxAll)
                {// the bktId of maxAll will fall out of bucket range
                    int bktId = (int)((nums[i]-minAll)/gap);
                    minV[bktId] = min(minV[bktId], nums[i]);
                    maxV[bktId] = max(maxV[bktId], nums[i]);
                }
            }
            int ret = 0;
            int curMax = maxV[0];
            for(int i = 1; i < n-1; i ++)
            {
                if(minV[i] != INT_MAX)
                {
                    ret = max(ret, minV[i]-curMax);
                    curMax = maxV[i];
                }
            }
            ret = max(ret, maxAll-curMax);
            return ret;
        }
    };

  • 相关阅读:
    UItableView的cell重用机制
    iOS开发中常遇到的面试题
    iOS UIScrollView 的基本用法
    iOS的CocoaPods手动挡到自动挡到导入第三方框架 转发
    iOS之NSPredicate(正则表达式和UIBarController):谓词
    iOS UISearchController 搜索框
    PHP 基本用法及基本知识点
    iOS 九宫格的实现
    iOS XML 系统自带的解析方法
    iOS xml文件的解析方式 XMLDictionary,GDataXMLNode,NSXMLParser 转发自徒步天涯
  • 原文地址:https://www.cnblogs.com/ganganloveu/p/4162290.html
Copyright © 2020-2023  润新知