计数排序的一种变形

这是一种不稳定的排序

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

vector<int> CountSort(const vector<int> & vecNum)
{
    vector<int> vecNumSort;

    if (vecNum.empty()) return vecNumSort;

    vector<int> vecCount;
    int nJizhi = 0;
    int nSize  = 0;
    int nMax   = vecNum[0];
    int nMin   = vecNum[0];
    for (auto itr=vecNum.begin();
          itr!=vecNum.end();
          ++itr)
    {
        if (nMax < *itr) nMax = *itr;
        if (nMin > *itr) nMin = *itr;
    }

    nJizhi = nMin;
    nSize  = nMax - nMin + 1;

    vecCount.assign(nSize, 0);
    for (auto itr=vecNum.begin();
          itr!=vecNum.end();
          ++itr)
    {
        vecCount[*itr-nJizhi] += 1; 
    }

    for (int i=0; i<vecCount.size(); ++i)
    {
        for (int j=0; j<vecCount[i]; ++j) {
            vecNumSort.push_back(i+nJizhi);
        }
    }

    return vecNumSort;
}

void Output(int a)
{
    cout << a << " ";
}

int main(int argc, char ** argv)
{
    const int LEN = 8;
    int a[LEN] = {2, 5, 3, 1, 2, 3, 1, 3};
    vector<int> vecNum(a, a+LEN);
    for_each(vecNum.begin(), vecNum.end(), Output);
    cout << endl;
    vecNum = CountSort(vecNum);
    for_each(vecNum.begin(), vecNum.end(), Output);
    cout << endl;
    return 0;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 排序的基本概念 在计算机程序开发过程中,经常需要一组数据元素(或记录)按某个关键字进行排序,排序完成的序列可用于快...
    Jack921阅读 5,356评论 1 4
  • 总结一下常见的排序算法。 排序分内排序和外排序。内排序:指在排序期间数据对象全部存放在内存的排序。外排序:指在排序...
    jiangliang阅读 5,239评论 0 1
  • 一、 单项选择题(共71题) 对n个元素的序列进行冒泡排序时,最少的比较次数是( )。A. n ...
    貝影阅读 13,044评论 0 10
  • 前言 本篇文章基本是从常用排序算法总结(一)快速排序引申而来,其中大部分代码和描述都来自这两篇文章。 时间复杂度 ...
    王三的猫阿德阅读 4,818评论 0 1
  • 我想,这世上的人和事,只要念念不忘,必有回响!
    有风来过19阅读 3,034评论 0 1