• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            計數排序

            計數排序實現:以學生年齡對學生信息進行排序。
             1 #include <iostream>
             2 #include <vector>
             3 #include <string>
             4 #include <algorithm>
             5 using namespace std;
             6 
             7 typedef struct StudentInfo 
             8 {
             9     unsigned int age;
            10     string name;
            11     string major;
            12 }StudentInfo;
            13 
            14 struct StudentCount 
            15 {
            16     void operator()(StudentInfo stuInfo)
            17     {
            18         cout << stuInfo.name << " " << stuInfo.age << stuInfo.major << endl;
            19     }
            20 }student;
            21 
            22 void Countsort(vector<StudentInfo> &vec, unsigned int nMaxAge)
            23 {
            24     unsigned int* nCount = (unsigned int*)malloc(sizeof(unsigned int)*nMaxAge);
            25     //vector<unsigned int> nCount(nMaxAge, 0);
            26     memset(nCount, 0sizeof(unsigned int)*nMaxAge); //assign 0 to the array nCount
            27     vector<StudentInfo>::const_iterator iter = vec.begin();
            28     
            29     //count the number of each age
            30     for (; iter != vec.end(); ++iter) //用for_each試一下
            31     {
            32         ++nCount[iter->age];
            33     }
            34 
            35     //確定有多少個數據在當前元素的前面
            36     for (int i = 1; i < nMaxAge; ++i)
            37     {
            38         nCount[i] += nCount[i-1];
            39     }
            40 
            41     vector<StudentInfo> StudentSorted;
            42     StudentSorted.reserve(vec.size()); //使用reserve預分配空間,這些空間是否有初始值呢?
            43     StudentSorted.resize(vec.size());
            44     for (int i = 0; i < vec.size(); ++ i)
            45     {
            46         int index = --nCount[vec[i].age];
            47          StudentSorted[index] = vec[i];
            48     }
            49 
            50     //將StudentSorted數據復制到vec中。
            51     vec.swap(StudentSorted);
            52     //for_each(vec.begin(), vec.end(), student);
            53     free(nCount);
            54     nCount = NULL;
            55 }
            56 int main()
            57 {
            58     vector<StudentInfo> vec;
            59     //初始化vec中的數據
            60     for (int i = 0; i < 20++i)
            61     {
            62         StudentInfo stuInfo = {i%10"qinlei""CS"};
            63         vec.push_back(stuInfo);
            64     }
            65 
            66     //開始排序
            67     Countsort(vec, 20);
            68     //打印排序后的結果
            69     for_each(vec.begin(), vec.end(), student);
            70     return 0;
            71 }

            posted on 2011-06-04 23:50 MrRightLeft 閱讀(249) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            <2012年4月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導航

            統計

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            狠狠色噜噜狠狠狠狠狠色综合久久| 国产女人aaa级久久久级| 无码人妻精品一区二区三区久久| 亚洲中文精品久久久久久不卡| 欧美亚洲国产精品久久蜜芽 | 久久久久久精品无码人妻| 久久久久波多野结衣高潮| 国产精品九九久久免费视频| 香蕉久久av一区二区三区| 狠狠人妻久久久久久综合蜜桃 | 亚洲午夜无码久久久久小说| 久久777国产线看观看精品| 国产精品久久久久久久久久影院| 久久婷婷久久一区二区三区| 97精品依人久久久大香线蕉97 | 粉嫩小泬无遮挡久久久久久| 伊人色综合九久久天天蜜桃| 精品久久人人做人人爽综合| 久久精品人人做人人爽电影蜜月| 久久久久久免费视频| 午夜精品久久久久成人| 久久精品人妻一区二区三区| 香蕉久久一区二区不卡无毒影院 | 亚洲国产一成人久久精品| 午夜不卡888久久| 国产精品无码久久综合| 少妇人妻88久久中文字幕| 中文字幕无码免费久久| 久久久久久亚洲精品影院| 精品国产91久久久久久久a| 99麻豆久久久国产精品免费| 日韩AV无码久久一区二区| 亚洲伊人久久大香线蕉综合图片| 国产成人综合久久精品红| 亚洲精品NV久久久久久久久久| 亚洲v国产v天堂a无码久久| 亚洲欧美日韩精品久久亚洲区| 久久久WWW成人免费精品| 久久婷婷色综合一区二区| 久久国产精品无| 久久99久久99精品免视看动漫 |