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

隨感而發

雜七雜八

統計

留言簿(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>
            久久久精品日韩欧美| 欧美尤物一区| 伊人久久av导航| 亚洲视频网在线直播| 在线日韩日本国产亚洲| 小处雏高清一区二区三区| 亚洲天堂av综合网| 欧美成人性生活| 久久亚洲私人国产精品va| 国产欧美日韩视频| 国产精品99久久不卡二区| 99国内精品久久| 久久夜色撩人精品| 蜜臀久久99精品久久久画质超高清| 国产精品久久毛片a| 亚洲人www| 亚洲精品视频在线观看网站| 久久偷窥视频| 欧美成人激情视频| 一区视频在线| 久久成人在线| 麻豆成人精品| 在线欧美日韩精品| 久久久久久久国产| 久久夜精品va视频免费观看| 国产在线播精品第三| 性色一区二区| 欧美在线日韩精品| 国内精品久久久久久久果冻传媒| 欧美一级理论性理论a| 欧美一区二区三区在线免费观看 | 欧美理论电影网| 亚洲高清不卡一区| 日韩一级免费| 国产精品v欧美精品v日韩| 亚洲一区二区动漫| 久久精品国产一区二区三区免费看| 国产日韩综合| 久久久综合网| 亚洲国产另类精品专区| 一本色道久久99精品综合| 欧美视频在线观看一区| 亚洲欧洲av一区二区| 久久久久看片| 亚洲美女色禁图| 国产精品白丝av嫩草影院| 亚洲欧美视频在线| 免费短视频成人日韩| 夜夜嗨网站十八久久| 国产精品一区一区| 久久综合狠狠综合久久综合88| 亚洲国产日韩欧美| 亚洲欧美高清| 在线看片一区| 国产精品女人网站| 蜜桃久久av一区| 国产精品99久久久久久有的能看| 久久久久久成人| 一区二区免费在线视频| 国产又爽又黄的激情精品视频| 欧美风情在线| 亚洲欧美在线高清| 亚洲日本无吗高清不卡| 久久久久国产一区二区三区| 亚洲乱亚洲高清| 国产日本欧洲亚洲| 欧美欧美全黄| 久久久久久久久综合| 亚洲图片欧洲图片av| 欧美激情一二三区| 久久久久88色偷偷免费| 在线中文字幕不卡| 在线欧美日韩| 国产婷婷色一区二区三区在线| 欧美激情一区二区三区不卡| 欧美亚洲视频在线观看| 亚洲最新色图| 亚洲第一色中文字幕| 久久欧美中文字幕| 午夜精品久久| 中文av一区二区| 亚洲精品婷婷| 亚洲国产欧美日韩精品| 国一区二区在线观看| 国产精品欧美风情| 欧美午夜一区二区| 欧美激情一区二区三区四区| 久久久久成人网| 欧美在线视屏| 午夜欧美大片免费观看| 亚洲一区二区三区四区五区午夜 | 欧美91大片| 久久久人成影片一区二区三区观看 | 美女福利精品视频| 久久精品国产99国产精品| 亚洲一区综合| 亚洲天堂av电影| 一区二区三区导航| 日韩视频在线免费| 亚洲精品美女在线| 亚洲人成人一区二区三区| 欧美韩日一区二区三区| 免费久久99精品国产自在现线| 久久久国产精品一区二区三区| 性欧美暴力猛交69hd| 午夜久久影院| 欧美专区亚洲专区| 久久福利毛片| 久久综合成人精品亚洲另类欧美| 久久久综合免费视频| 久久久夜夜夜| 欧美第一黄网免费网站| 欧美成人综合| 亚洲国产一区二区三区高清| 亚洲欧洲精品一区| 亚洲乱码精品一二三四区日韩在线 | 欧美肥婆bbw| 亚洲国产天堂久久国产91| 亚洲国产欧美日韩| 亚洲免费观看在线观看| 一区二区三区视频观看| 亚洲字幕一区二区| 久久久久久久一区二区三区| 鲁大师成人一区二区三区| 欧美区在线观看| 国产精品免费视频观看| 好看的日韩视频| 亚洲人成人一区二区在线观看| 一区二区欧美在线观看| 午夜久久tv| 免费中文字幕日韩欧美| 亚洲精品一区中文| 午夜国产精品影院在线观看| 久久男人资源视频| 欧美日韩精品二区第二页| 国产欧美日韩视频一区二区三区| 红桃视频一区| 亚洲视频狠狠| 美女图片一区二区| 日韩视频免费观看高清完整版| 亚洲欧美激情精品一区二区| 裸体一区二区| 国产精品白丝黑袜喷水久久久| 精品动漫3d一区二区三区| 一区二区三区精品视频| 久久久久这里只有精品| 日韩一级成人av| 久久精品中文| 国产精品国产成人国产三级| 亚洲大胆视频| 欧美一区二区观看视频| 亚洲全黄一级网站| 久久高清免费观看| 欧美午夜不卡视频| 亚洲精华国产欧美| 久久电影一区| 一区二区三区三区在线| 嫩模写真一区二区三区三州| 国产欧美一区二区精品秋霞影院 | 一区二区三区视频在线观看| 久久久一区二区| 国产欧美一区在线| 一区二区三区免费在线观看| 猫咪成人在线观看| 亚洲欧美日韩国产综合| 欧美日韩一区二区三区在线视频| 激情综合色丁香一区二区| 亚洲欧美中文日韩在线| 亚洲人成艺术| 欧美成人免费全部| 一区精品在线播放| 久久精品99无色码中文字幕| 一个人看的www久久| 欧美精品午夜| 亚洲国产精品电影| 久久综合色播五月| 午夜伦理片一区| 国产乱码精品一区二区三区五月婷| 一区二区三区四区国产| 亚洲电影免费观看高清完整版| 久久青草欧美一区二区三区| 国产亚洲人成a一在线v站| 欧美一级理论片| 亚洲一区在线观看视频 | 欧美人与禽性xxxxx杂性| 亚洲精品国产日韩| 亚洲电影成人| 欧美成人a∨高清免费观看| 亚洲国产高清一区二区三区| 蜜桃久久av一区| 久久免费黄色| 亚洲区国产区| 最新精品在线| 欧美日韩一区二区视频在线| 在线亚洲激情| 亚洲午夜伦理| 国产一区二区三区免费观看| 久久久一二三| 欧美成人久久| 这里只有精品视频|