C++步步为营Algorithm

Counting Sort

2019-07-18  本文已影响0人  世界上的一道风
class Solution {
public:
    void sortColors(vector<int>& nums) {
        vector<int> temp{0, 0, 0};
        vector<int> B(nums.size());
        
        //   以下循环操作完成后,temp的第i个位置保存着nums中,值为i的元素的总个数
        for(auto elem:nums)
        {
            temp[elem]++;
        }
        // 以下循环操作完成后,temp的第i个位置保存着nums中,值小于或等于i的元素的总个数
        for(auto i=1; i<temp.size(); ++i)
        {
            temp[i] += temp[i-1];
        }
        //
        for(int i=nums.size()-1; i>-1; --i)
        {
            cout << i << endl;
            B[temp[nums[i]] - 1] = nums[i];
            temp[nums[i]]--; 
        }
        nums = B;
    }
};

总的运行时间是\Theta(k+n)。当k= O(n)时,运行时间为\Theta(n)
结论:可以看出,计数排序的下界优于比较排序算法的下界时间Ω(nlgn)。这是因为计数排序并不是比较排序算法。

参考:https://www.cnblogs.com/dongkuo/p/4832849.html

上一篇下一篇

猜你喜欢

热点阅读