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

隨感而發

雜七雜八

統計

留言簿(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 閱讀(2395) 評論(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>
            欧美一区二区精品久久911| 久久九九精品| 亚洲图片自拍偷拍| 日韩视频精品| 亚洲国产一二三| 在线性视频日韩欧美| 香港成人在线视频| 一区二区三区**美女毛片| 欧美激情精品久久久久久久变态| 久久乐国产精品| 欧美一级视频免费在线观看| 欧美午夜片在线观看| 国产精品99久久久久久有的能看| 亚洲精品视频在线| 欧美日韩在线综合| 亚洲午夜精品久久久久久浪潮| 亚洲精品一区二区三区樱花| 欧美日韩在线观看一区二区| 亚洲午夜精品在线| 亚洲综合日本| 黄色成人精品网站| 欧美激情一区二区三区在线视频 | 美日韩精品免费| 久久综合九九| 亚洲精品乱码久久久久久日本蜜臀 | 日韩视频一区二区| 亚洲精品在线三区| 欧美四级伦理在线| 亚洲一区二区三区在线视频| 在线视频中文亚洲| 国产一区二区三区四区五区美女| 老司机午夜精品| 欧美黄色一区| 亚洲欧美日韩视频一区| 欧美在线观看视频一区二区三区| 伊人激情综合| 亚洲高清不卡一区| 欧美日韩不卡视频| 欧美一区在线视频| 麻豆精品国产91久久久久久| 99国产精品99久久久久久| 一区二区日本视频| 国产亚洲一区在线| 亚洲第一福利视频| 国产精品久久久久永久免费观看| 久久久久久久久久久成人| 久久影院亚洲| 亚洲一区999| 久久久精品国产免大香伊| 亚洲日韩欧美视频| 亚洲影视在线播放| 最近看过的日韩成人| 日韩亚洲欧美中文三级| 国产小视频国产精品| 亚洲国产二区| 国产欧美亚洲视频| 亚洲国产一区二区三区在线播 | 亚洲国产精品精华液2区45| 日韩一级在线观看| 亚洲第一二三四五区| 国产精品久久夜| 久久字幕精品一区| 欧美视频精品在线| 欧美成人黑人xx视频免费观看| 欧美日韩精品免费观看| 久久综合色天天久久综合图片| 欧美国产精品| 国产美女精品视频| 91久久精品国产91性色tv| 国产区精品在线观看| 亚洲精品久久久久中文字幕欢迎你| 国产目拍亚洲精品99久久精品| 亚洲国产婷婷香蕉久久久久久| 国产丝袜美腿一区二区三区| 日韩午夜精品| 亚洲精品综合久久中文字幕| 久久久久久久久久久久久9999| 亚洲一区久久| 欧美久久99| 亚洲国产成人精品视频 | 欧美一区二区三区精品| 欧美精品久久99久久在免费线| 久久久久久夜| 国产亚洲欧美日韩在线一区 | 国产精品日韩精品欧美精品| 亚洲美女区一区| 亚洲精品偷拍| 你懂的视频一区二区| 久久综合网络一区二区| 国产女主播在线一区二区| 在线中文字幕一区| 亚洲欧美电影院| 国产精品久久久久久五月尺| 亚洲乱码日产精品bd| 亚洲每日更新| 欧美日本在线视频| 亚洲精品国产品国语在线app| 亚洲激情成人| 欧美激情视频一区二区三区不卡| 亚洲成人在线视频播放| 国产日韩欧美综合精品| 亚洲欧美日韩国产一区二区三区 | 六月丁香综合| 在线不卡中文字幕| 久久影音先锋| 亚洲区在线播放| 亚洲午夜成aⅴ人片| 国产精品久线观看视频| 亚洲在线国产日韩欧美| 久久国产主播精品| 激情文学综合丁香| 欧美成年视频| 夜夜嗨av一区二区三区四区| 亚洲影院污污.| 国产偷国产偷精品高清尤物| 欧美有码在线视频| 欧美成年人视频网站欧美| 亚洲伦理一区| 国产精品欧美久久久久无广告| 午夜在线精品| 欧美激情一区| 亚洲欧美国产日韩中文字幕| 国产日韩欧美综合一区| 午夜精品久久久久久99热软件| 久久av免费一区| 麻豆av一区二区三区久久| 在线观看日韩av电影| 欧美乱妇高清无乱码| 亚洲欧美在线播放| 欧美电影在线播放| 亚久久调教视频| 91久久精品一区二区三区| 欧美日韩在线播放| 久久成人国产| 亚洲精品一区二区三区av| 欧美一级大片在线观看| 在线不卡a资源高清| 国产精品豆花视频| 久久精品综合| 在线视频精品一| 美脚丝袜一区二区三区在线观看| 在线亚洲欧美| 亚洲电影免费观看高清完整版在线观看| 欧美激情麻豆| 欧美在线网址| 国产精品99久久久久久有的能看| 另类天堂av| 欧美一区二区三区日韩视频| 亚洲另类黄色| 一区在线电影| 国产精品久久777777毛茸茸| 免费久久99精品国产自| 欧美一级片一区| 在线视频一区观看| 亚洲国内在线| 欧美 日韩 国产精品免费观看| 欧美亚洲网站| 亚洲在线播放电影| 亚洲精品影院在线观看| 黄色国产精品| 国产精品一区二区三区乱码| 欧美日韩国产一中文字不卡| 久久综合久色欧美综合狠狠| 欧美一级播放| 亚洲欧美一区二区精品久久久| 99精品视频一区| 亚洲电影观看| 欧美激情黄色片| 欧美成人网在线| 你懂的国产精品永久在线| 久久理论片午夜琪琪电影网| 久久国产精品网站| 久久国产精彩视频| 性欧美1819sex性高清| 亚洲免费视频中文字幕| 一区二区高清视频| 日韩午夜中文字幕| 亚洲美女黄色| 99视频一区二区三区| 亚洲精品免费在线播放| 亚洲激情成人| 一本一道久久综合狠狠老精东影业| 亚洲国产欧美日韩精品| 亚洲啪啪91| 99精品久久| 一区二区久久久久| 亚洲香蕉网站| 欧美一级大片在线观看| 久久精品国产99国产精品| 久久精视频免费在线久久完整在线看| 欧美一区二区三区的| 久久精品夜色噜噜亚洲aⅴ| 久久精品一级爱片| 久久综合图片| 亚洲国产成人tv| 中日韩午夜理伦电影免费| 亚洲一区二区三区中文字幕在线| 亚洲在线一区二区三区| 久久高清福利视频| 亚洲大片免费看|