青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨感而發

雜七雜八

統計

留言簿(13)

閱讀排行榜

評論排行榜

快速排序學習4(最初版加隨機版)

這是最初版本的和隨機版本的結合,我也修改了一下最初版本的小點東西,思路還是最初版的思路,只是我把分割符中的數據排好了而已。呵呵。。也沒有什么號說的。奉上源代碼:
#include <stdio.h>
#include 
<stdlib.h>
#include 
<time.h>

//化分區間,找到最后元素的排序位置。并返回分隔的點(即最后一數據排序的位置)。
//劃分的區間是[nBegin, nEnd). pData是保存數據的指針
int Partition(int* pData, int nBeging, int nEnd)
{
    
int i = nBeging + rand()%(nBeging - nEnd);
    
//這里是和hoare的思路寫的,和原版本不是完全一樣,思路是一樣的。
    int x = pData[i];
    pData[i] 
= pData[nBeging];
    pData[nBeging] 
= x;
    
//int x = pData[nBeging];
    --nEnd;

    
while (nBeging < nEnd)
    
{
        
//從后向前,找到比X小的元素位置
        while(pData[nEnd] > x)
        
{
            
--nEnd;
        }

        
//把x小的元素位置提前,nBegin處剛好能保存比x小的元素
        if (nBeging < nEnd)
        
{
            pData[nBeging] 
= pData[nEnd];    
            pData[nEnd] 
= x;    //這里是為了做一個哨兵,防止小區域增加時越界。
            ++nBeging;
        }


        
//小的區域增加,找到一個不比x小的元素。
        while (pData[nBeging] < x)
        
{
            
++nBeging;
        }


        
//把不比x小的元素存放在大的區域內。nEnd剛好預留了此位置。
        if (nBeging < nEnd)
        
{
            pData[nEnd] 
= pData[nBeging];
            
--nEnd;
        }

    }


    pData[nBeging] 
= x;    //這里一定要賦值,不然如果是nEnd退出循環,他是保存著以前的大值,會出錯。
    return nBeging;   //返回nD的位置,就是分割的位置。
}


//排序的遞歸調用。
int QuickSortRecursion(int* pData, int nBeging, int nEnd)
{
    
if (nBeging >= nEnd -1)        //如果區域不存在或只有一個數據則不遞歸排序
    {
        
return 1;
    }


    
//這里因為分割的時候,分割點處的數據就是排序中他的位置。
    
//也就是說他的左邊的數據都小于等于他,他右邊的數據都大于他。
    
//所以他不在遞歸調用的數據中。
    int i = Partition(pData, nBeging, nEnd);        //找到分割點

    QuickSortRecursion(pData, nBeging, i);            
//遞歸左邊的排序
    QuickSortRecursion(pData, i + 1, nEnd);            //遞歸右邊的排序
    return 1;
}


//快速排序
int QuickSort(int* pData, int nLen)
{
    srand((unsigned 
int)time(NULL));
    
//遞歸調用,快速排序。
    QuickSortRecursion(pData, 0, nLen);
    
return 1;
}

int main()
{
    
int nData[10= {2,6,3,4,1,5,7,8,10,9};        //測試數據
    QuickSort(nData, 10);
    
for (int i = 0; i < 10++i)
    
{
        printf(
"%d ", nData[i]);
    }

    printf(
"\n");
    
    system(
"pause");
    
return 0;
}

posted on 2009-04-23 21:09 shongbee2 閱讀(2398) 評論(1)  編輯 收藏 引用 所屬分類: 數據結構和算法

評論

# re: 快速排序學習4(最初版加隨機版) 2013-09-20 18:05 LAYU

if (nBeging >= nEnd -1) //如果區域不存在或只有一個數據則不遞歸排序
{
return 1;
}



改成比較好些,當數組為兩個元素時,就排不出來了
if (nBeging >= nEnd) //如果區域不存在或只有一個數據則不遞歸排序
{
return 1;
}  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产综合视频| 亚洲免费久久| 国产精品一区视频网站| 亚洲国产精品视频| 狠狠色综合一区二区| 亚洲综合色网站| 亚洲视频导航| 欧美久久在线| 亚洲国产成人高清精品| 亚洲电影在线播放| 久久国产精品99国产| 久久av在线| 国产精品有限公司| 亚洲男人的天堂在线观看| 在线亚洲观看| 欧美视频成人| 一区二区三区国产盗摄| 亚洲视频一二三| 欧美日韩综合不卡| 一区二区激情小说| 亚洲男人天堂2024| 国产精品丝袜91| 亚洲图片自拍偷拍| 欧美亚洲在线观看| 国产欧美日韩中文字幕在线| 亚洲网站在线播放| 欧美专区第一页| 国模一区二区三区| 久久综合激情| 91久久在线| 亚洲影院色无极综合| 国产精品久在线观看| 午夜一区二区三区不卡视频| 久久精品一区二区三区不卡| 精品福利电影| 欧美国产日韩一二三区| 日韩视频中文字幕| 亚洲欧美激情一区| 国产综合激情| 欧美国产激情| 一区二区福利| 久久久天天操| 亚洲美女中文字幕| 国产精品久久久久天堂| 欧美资源在线| 亚洲人成人99网站| 欧美一级成年大片在线观看| 精品99一区二区| 欧美经典一区二区| 亚洲永久精品国产| 欧美h视频在线| 一本色道久久88综合日韩精品| 国产精品a久久久久久| 久久成人在线| 亚洲精品视频在线播放| 久久国产福利国产秒拍| 亚洲人成艺术| 国产欧美精品国产国产专区| 噜噜噜91成人网| 亚洲午夜性刺激影院| 欧美成人高清视频| 午夜精品电影| 亚洲欧洲一区二区在线观看| 国产精品一区在线观看你懂的| 麻豆久久婷婷| 亚洲欧美电影院| 亚洲精品久久久久久久久久久| 久久riav二区三区| 99国产精品久久久久久久久久| 国产色产综合色产在线视频 | 亚洲国产综合在线| 欧美在线首页| 一区二区精品国产| 伊人久久久大香线蕉综合直播| 欧美日韩综合| 欧美成人乱码一区二区三区| 午夜精品久久久久99热蜜桃导演| 亚洲黄网站在线观看| 玖玖在线精品| 久久精品二区| 午夜精品一区二区三区在线视| 亚洲黄色在线视频| 国模私拍一区二区三区| 国产精品麻豆成人av电影艾秋| 欧美激情精品久久久久久蜜臀| 久久久精品动漫| 午夜精品福利在线观看| 在线视频你懂得一区| 亚洲人成在线观看网站高清| 免费亚洲一区| 久久久久网址| 久久激情视频免费观看| 亚洲欧美视频一区二区三区| 一区二区三区四区五区精品| 亚洲国产精品激情在线观看| 曰韩精品一区二区| 狠狠色综合网| 国外成人在线视频| 狠狠色狠狠色综合日日小说| 国产人成一区二区三区影院| 国产精品夜色7777狼人| 国产精品激情电影| 国产精品xxxav免费视频| 欧美亚洲成人精品| 欧美午夜精品久久久久免费视 | 中日韩视频在线观看| 亚洲精品在线免费| 99精品热6080yy久久| 99国产精品国产精品久久| 亚洲乱码国产乱码精品精可以看 | 一区二区亚洲精品| 国产精品麻豆va在线播放| 国产精品久久一区主播| 国产精品亚洲一区| 国产亚洲电影| 在线观看日韩一区| 亚洲人www| 亚洲性色视频| 欧美主播一区二区三区| 久久综合激情| 亚洲国内在线| 亚洲一区三区视频在线观看 | 99伊人成综合| 亚洲欧美欧美一区二区三区| 午夜久久久久| 免费成人av资源网| 欧美婷婷六月丁香综合色| 国产乱肥老妇国产一区二| 国户精品久久久久久久久久久不卡| 韩国成人精品a∨在线观看| 亚洲电影免费观看高清完整版在线| 亚洲毛片在线看| 亚洲欧美国产高清va在线播| 久久久久久久综合色一本| 亚洲国产91| 亚洲一区二区在线观看视频| 欧美一区二区在线免费播放| 免费在线一区二区| 国产精品久久国产愉拍| 韩国一区二区三区在线观看 | 91久久精品国产91久久| 国产精品99久久久久久久女警| 欧美一区二区三区久久精品| 麻豆精品视频在线观看| 国产精品久久久久久久久久久久久久 | 韩国女主播一区二区三区| 亚洲精品黄色| 久久久久免费视频| 9l国产精品久久久久麻豆| 久久久成人网| 国产精品久久久久久久app| 在线成人av.com| 亚洲欧美日韩在线高清直播| 欧美高清视频在线观看| 亚洲自拍高清| 欧美日韩另类在线| 亚洲成色777777在线观看影院| 亚洲综合三区| 亚洲区在线播放| 久久免费黄色| 国产亚洲精品综合一区91| 亚洲天堂成人| 亚洲国产一区二区视频| 久久精品一区二区三区中文字幕| 欧美视频在线观看视频极品| 亚洲福利视频专区| 久久免费精品视频| 亚洲女女女同性video| 欧美日韩一二三四五区| 亚洲精品视频二区| 欧美69wwwcom| 久久国产直播| 国产视频久久| 欧美一区二区三区精品| 正在播放亚洲一区| 欧美日韩国产专区| 一本色道久久综合亚洲精品不 | 猫咪成人在线观看| 午夜在线精品偷拍| 国产精品美女在线观看| 亚洲影视九九影院在线观看| 亚洲人成小说网站色在线| 免费视频亚洲| 亚洲黄色一区二区三区| 免费成人黄色av| 久久午夜精品一区二区| 在线观看成人小视频| 蜜臀av一级做a爰片久久 | 亚洲欧美中文另类| 国产精品视屏| 欧美在线视频一区二区| 午夜亚洲福利| 精品成人国产| 欧美第一黄色网| 免费成人网www| 亚洲免费电影在线观看| 日韩视频国产视频| 国产精品爱久久久久久久| 午夜国产精品视频| 亚洲女同精品视频|