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

隨筆 - 26  文章 - 6  trackbacks - 0
<2010年4月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

朋友

  • cqh
  • 大學室友...

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 

#include <iostream>
#include 
<assert.h>
using namespace std;

const int MAXN = 1020;


/**
* @brief 選擇排序(不穩定)
* @param nX        需要排序的數值
* @param nNum    數值的長度
* @return true    代表處理成功
*/

bool select_sort(int *nX, int nNum)
{
    assert(nX 
!= NULL && nNum >= 1);
    
int i, j, nMin;
    
for (i = 0; i < nNum - 1; i++)
    
{
        nMin 
= i;
        
for (j = i+1; j < nNum; j++)
        
{
            
if (nX[j] < nX[nMin])
            
{
                nMin 
= j;
            }

        }

        
if (nMin != i)
        
{
            swap(nX[nMin], nX[i]);
        }

    }

    
return true;
}
 


/**
* @brief 插入排序(穩定)
* @param nX        需要排序的數值
* @param nNum    數值的長度
* @return true    代表處理成功
*/

bool insert_sort(int *nX, int nNum)
{
    assert(nX 
!= NULL && nNum >= 1);
    
int i, j, nTmp;
    
for (i = 1; i < nNum; i++)
    
{
        nTmp 
= nX[i];
        
for (j = i-1; j >= 0 && nTmp < nX[j]; j--)
        
{
            nX[j
+1= nX[j];
        }

        nX[j
+1= nTmp;
    }

    
return true;
}
 


/**
* @brief 冒泡排序(穩定)
* @param nX        需要排序的數值
* @param nNum    數值的長度
* @return true    代表處理成功
*/

bool bubble_sort(int *nX, int nNum)
{
    assert(nX 
!= NULL && nNum >= 1);
    
int i, j;
    
for (i = nNum - 1; i >= 0; i--)
    
{
        
for (j = 0; j < i; j++)
        
{
            
if(nX[j] > nX[j+1])
                swap(nX[j], nX[j
+1]);
        }

    }

    
return true;
}
 



/**
* @brief 希爾排序(不穩定)
* @param nX        需要排序的數值
* @param nNum    數值的長度
* @return true    代表處理成功
*/

bool shell_sort(int *nX, int nNum)
{
    assert(nX 
!= NULL && nNum >= 1);
    
int i, j, nH, nTmp;
    
for (nH = nNum/2; nH > 0; nH /= 2)
    
{
        
//n - nH 趟冒泡
        for (i = nH; i < nNum; i++)
        
{
            
//一趟冒泡
            nTmp = nX[i];
            
for (j = i-nH; j >= 0 && nTmp < nX[j]; j -= nH)
            
{
                nX[j
+nH] = nX[j];
            }

            nX[j
+nH] = nTmp;
        }

    }

    
return true;
}



/**
* @brief 快速排序(不穩定)
* @param nX        需要排序的數值
* @param nLow    開始元素的下標
* @param nHigh    結束元素的下標
*/

void quick_sort(int *nX, int nLow, int nHigh)
{
    assert(nX 
!= NULL);

    
if (nLow >= nHigh)
    
{
        
return ;
    }


    
int nTmp, i = nLow, j = nHigh;
    nTmp 
= nX[nLow];
    
while (i < j)
    
{
        
while (i < j && nX[j] >= nTmp)
        
{
            j
--;
        }

        nX[i] 
= nX[j];
        
while (i < j && nX[i] <= nTmp)
        
{
            i
++;
        }

        nX[j] 
= nX[i];
    }

    nX[i] 
= nTmp;

    quick_sort(nX, nLow,  i
-1);
    quick_sort(nX, i
+1, nHigh);
}




/**
* @brief 建最大堆
* @param nX        需要排序的數值
* @param nNum    數值的長度
* @param nStart    從第幾個元素開始
* @return true    代表處理成功
*/

void sift(int *nX, int nNum, int nStart)
{
    assert(nX 
!= NULL && nNum >= 1);
    
int nTmp, k, j;
    nTmp 
= nX[nStart];
    k 
= nStart;
    j 
= 2*+ 1;
    
while (j < nNum)
    
{
        
//選擇子節點較大的
        if (j < nNum -1 && nX[j] < nX[j+1])
        
{
            j
++;
        }

        
//向下調整
        if (nTmp < nX[j])
        
{
            nX[k] 
= nX[j];
            k 
= j;
            j 
= 2*+ 1;
        }

        
else
        
{
            
break;
        }

    }

    nX[k] 
= nTmp;
}


/**
* @brief 堆排序(不穩定)
* @param nX        需要排序的數值
* @param nNum    數值的長度
* @return true    代表處理成功
*/

bool heap_sort(int *nX, int nNum)
{
    assert(nX 
!= NULL && nNum >= 1);
    
int i, k;
    
for (i = nNum/2-1; i >= 0; i--)
    
{
        sift(nX, nNum, i);
    }


    
for (k = nNum-1; k >= 1; k--)
    
{
        swap(nX[
0], nX[k]);
        sift(nX, k, 
0);
    }

    
return true;
}



/**
* @brief 將nX[]的[nLow, nMiddle]和[nMiddle+1, nHigh]合并,并保存到nB[]中
* @param nX    源數組
* @param nB 目的數組
* @param nLow    開始元素的下標
* @param nMiddle 中間下標
* @param nHigh    結束元素的下標
*/

void merge(int *nX, int *nB, int nLow, int nMiddle, int nHigh)
{
    
int i = nLow, j = nMiddle + 1, k = nLow;
    
while ((i <= nMiddle) && (j <= nHigh))
    
{
        
if (nX[i] <= nX[j])
        
{
            nB[k
++= nX[i++];
        }

        
else
        
{
            nB[k
++= nX[j++];
        }

    }


    
if (i > nMiddle)
    
{
        
for (int q = j; q <= nHigh; q++)
        
{
            nB[k
++= nX[q];
        }

    }

    
else
    
{
        
for (int q = i; q <= nMiddle; q++)
        
{
            nB[k
++= nX[q];
        }

    }

}


/**
* @brief 將nB[]復制到nX[] (從nLow到nHigh)
* @param nX    目的數組
* @param nB 源數組
* @param nLow    開始元素的下標
* @param nHigh    結束元素的下標
*/

void copy(int *nX, int *nB, int nLow, int nHigh)
{
    
int i = 0;
    
for (i = nLow; i <= nHigh; i++)
    
{
        nX[i] 
= nB[i];
    }

}


/**
* @brief 合并排序(不穩定)
* @param nLow    開始元素的下標
* @param nHigh    結束元素的下標
*/

void merge_sort(int *nX, int nLow, int nHigh)
{
    assert(nX 
!= NULL);
    
    
if (nLow < nHigh)
    
{
        
int i = (nLow + nHigh)/2;
        merge_sort(nX, nLow, i);
        merge_sort(nX, i
+1, nHigh);
        
int nB[MAXN];
        merge(nX, nB, nLow, i, nHigh);
        copy(nX, nB, nLow, nHigh);
    }

}

posted on 2009-09-27 20:55 longshen 閱讀(356) 評論(0)  編輯 收藏 引用 所屬分類: 程序員
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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精品视频免费观看视频| 亚洲在线观看免费| 99综合电影在线视频| 另类激情亚洲| 久久亚洲精品中文字幕冲田杏梨| 性久久久久久久久| 亚洲视频高清| 欧美精选在线| 欧美激情亚洲国产| 亚洲大片在线观看| 久久久国际精品| 久久躁狠狠躁夜夜爽| 国产亚洲欧美一区| 亚洲欧美变态国产另类| 亚洲伊人观看| 国产精品久久久久91| aa级大片欧美三级| 亚洲午夜免费福利视频| 欧美日韩一区二区在线观看视频| 欧美激情一区二区在线| 亚洲电影网站| 美女视频黄 久久| 欧美激情欧美狂野欧美精品| 亚洲高清资源综合久久精品| 久久婷婷麻豆| 欧美大色视频| 亚洲伦理在线| 欧美日韩国产小视频在线观看| 亚洲靠逼com| 亚洲一卡久久| 国产欧美日韩一区二区三区| 欧美一级久久久| 久久免费高清| 亚洲欧洲一区二区在线观看| 欧美片在线播放| 一本久久青青| 久久成人免费| 在线看片日韩| 欧美激情综合网| 国产精品99久久久久久宅男| 欧美一区二区观看视频| 狠狠入ady亚洲精品| 暖暖成人免费视频| 99国产精品99久久久久久粉嫩| 亚洲综合视频网| 很黄很黄激情成人| 欧美激情亚洲激情| 亚洲午夜视频在线| 久久久精品五月天| 亚洲精品一区二区三区av| 欧美日韩中文| 欧美在线不卡| 91久久久在线| 欧美在线免费视频| 亚洲国产视频一区| 国产精品扒开腿做爽爽爽视频| 欧美一级专区| 最新国产拍偷乱拍精品| 欧美在线啊v| 亚洲日本一区二区三区| 国产精品久久久久久av下载红粉| 久久国产天堂福利天堂| 亚洲精品综合| 久久在线免费观看| 亚洲一区二区三区成人在线视频精品| 国产一区久久久| 欧美三级视频在线观看| 久久久久久久波多野高潮日日| 亚洲欧洲一区二区天堂久久| 久久久国产成人精品| 一区二区三区成人精品| 一区二区三区在线免费播放| 欧美午夜剧场| 免费在线观看日韩欧美| 欧美一级片在线播放| 99视频一区二区| 亚洲高清av在线| 欧美专区第一页| 亚洲综合成人在线| 日韩午夜电影| 亚洲高清视频中文字幕| 国产婷婷色一区二区三区| 欧美视频日韩| 欧美精品xxxxbbbb| 另类亚洲自拍| 久久久久一本一区二区青青蜜月| 亚洲一区二区精品| 日韩亚洲一区二区| 亚洲欧洲一级| 亚洲国产日韩在线| 欧美夫妇交换俱乐部在线观看| 欧美综合国产精品久久丁香| 亚洲一区二区三区在线视频| 日韩一级在线| 亚洲毛片在线看| 亚洲国产成人av在线| 一区二区三区在线视频观看 | 久久国内精品视频| 亚洲欧美一级二级三级| 亚洲一区二区三区影院| 一区二区日韩伦理片| 99国产精品99久久久久久粉嫩 | 亚洲精品乱码视频| 亚洲国产精品va在线看黑人动漫| 老司机精品导航| 美乳少妇欧美精品| 美女视频黄免费的久久| 欧美xart系列高清| 免费一区视频| 亚洲国产欧洲综合997久久| 亚洲电影有码| 亚洲日韩视频| 一区二区三区鲁丝不卡| 亚洲在线观看视频| 性欧美大战久久久久久久免费观看| 亚洲欧美清纯在线制服| 午夜欧美精品久久久久久久| 性欧美精品高清| 久久久人成影片一区二区三区| 久久久之久亚州精品露出| 可以看av的网站久久看| 欧美国产精品v| 欧美亚洲成人免费| 国产视频在线观看一区| 1204国产成人精品视频| 99精品欧美一区二区三区综合在线| 亚洲视频免费| 久久成人av少妇免费| 欧美成人免费va影院高清| 亚洲精品日产精品乱码不卡| 亚洲午夜视频在线观看| 久久久精品国产免大香伊| 欧美韩国一区| 国产精品美女诱惑| 在线成人av.com| 一区二区三区高清| 久久精品成人| 最近中文字幕日韩精品| 亚洲综合日韩在线| 久久婷婷麻豆| 国产精品福利片| 在线播放精品| 亚洲欧美视频在线观看视频| 久久青草欧美一区二区三区| 亚洲清纯自拍| 久久精品99国产精品日本| 欧美日韩爆操| 在线观看一区二区视频| 亚洲综合国产精品| 欧美国产专区| 欧美一级视频精品观看| 欧美另类videos死尸| 激情婷婷亚洲| 亚洲欧美激情在线视频| 亚洲国产高清一区| 久久黄色影院| 国产精品实拍| 在线视频免费在线观看一区二区| 久久久久国产免费免费| 中文久久精品| 欧美福利一区二区三区| 精品va天堂亚洲国产| 香蕉成人啪国产精品视频综合网| 亚洲第一页在线| 久久精品在线免费观看| 国产麻豆9l精品三级站| 亚洲午夜激情网页| 91久久综合亚洲鲁鲁五月天| 久久久久久日产精品| 国产日韩在线播放| 亚洲一区一卡| 亚洲乱码国产乱码精品精天堂 | 欧美一区二区精品| 亚洲日本aⅴ片在线观看香蕉| 久久久999精品| 国产综合久久久久久| 亚洲欧美卡通另类91av| 99日韩精品| 欧美日韩高清一区| 亚洲毛片av| 亚洲人成啪啪网站| 欧美高清影院| 亚洲七七久久综合桃花剧情介绍| 美女脱光内衣内裤视频久久网站| 欧美一区二区三区免费在线看| 国产精品每日更新| 午夜欧美视频| 亚洲主播在线观看| 国产毛片精品视频| 欧美中文在线字幕| 欧美亚洲在线观看| 国产在线不卡精品| 暖暖成人免费视频| 欧美.com| 亚洲视频一区在线| 亚洲午夜激情网页| 国产欧美精品xxxx另类| 久久久久久成人|