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

隨筆 - 26  文章 - 6  trackbacks - 0
<2009年9月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

朋友

  • cqh
  • 大學室友...

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 

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

const int MAXN = 1020;


/**
* @brief 選擇排序(不穩(wěn)定)
* @param nX        需要排序的數(shù)值
* @param nNum    數(shù)值的長度
* @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 插入排序(穩(wěn)定)
* @param nX        需要排序的數(shù)值
* @param nNum    數(shù)值的長度
* @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 冒泡排序(穩(wěn)定)
* @param nX        需要排序的數(shù)值
* @param nNum    數(shù)值的長度
* @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 希爾排序(不穩(wěn)定)
* @param nX        需要排序的數(shù)值
* @param nNum    數(shù)值的長度
* @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 快速排序(不穩(wěn)定)
* @param nX        需要排序的數(shù)值
* @param nLow    開始元素的下標
* @param nHigh    結(jié)束元素的下標
*/

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        需要排序的數(shù)值
* @param nNum    數(shù)值的長度
* @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)
    
{
        
//選擇子節(jié)點較大的
        if (j < nNum -1 && nX[j] < nX[j+1])
        
{
            j
++;
        }

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

        
else
        
{
            
break;
        }

    }

    nX[k] 
= nTmp;
}


/**
* @brief 堆排序(不穩(wěn)定)
* @param nX        需要排序的數(shù)值
* @param nNum    數(shù)值的長度
* @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    源數(shù)組
* @param nB 目的數(shù)組
* @param nLow    開始元素的下標
* @param nMiddle 中間下標
* @param nHigh    結(jié)束元素的下標
*/

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    目的數(shù)組
* @param nB 源數(shù)組
* @param nLow    開始元素的下標
* @param nHigh    結(jié)束元素的下標
*/

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

}


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

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>
            亚洲综合清纯丝袜自拍| 韩国一区二区三区在线观看| 日韩一级精品视频在线观看| 在线一区免费观看| 国产精品免费观看在线| 午夜精品在线观看| 欧美成人在线影院| 日韩午夜在线视频| 国产精品欧美经典| 久久综合图片| 日韩视频在线免费观看| 欧美在线一区二区三区| 亚洲国产成人av在线| 欧美日韩亚洲一区二区| 午夜免费日韩视频| 欧美激情视频一区二区三区在线播放 | 一区二区三区高清视频在线观看| 欧美人成网站| 欧美一区精品| 亚洲欧洲精品一区二区| 亚洲视频中文字幕| 国一区二区在线观看| 欧美日本不卡视频| 欧美在线不卡视频| 亚洲精品国产精品乱码不99按摩| 欧美亚洲一区二区三区| 亚洲三级毛片| 国产日韩欧美视频| 欧美日本三级| 久久久久久久综合| 在线综合亚洲欧美在线视频| 美女爽到呻吟久久久久| 亚洲在线免费观看| 亚洲国产精品成人久久综合一区| 欧美性视频网站| 老司机67194精品线观看| 亚洲视频综合| 欧美激情中文字幕乱码免费| 午夜综合激情| 一区二区三区四区精品| 亚洲高清影视| 国产日韩欧美二区| 欧美日韩综合在线免费观看| 久久亚洲图片| 欧美在线91| 亚洲一级二级| 亚洲狼人综合| 亚洲国产乱码最新视频| 美国十次成人| 久久久噜噜噜久久| 欧美一区二区三区啪啪 | 一本一本a久久| 雨宫琴音一区二区在线| 国产伦理一区| 国产精品久久久久一区二区三区共 | 亚洲精品影视| 91久久久久久| 最新国产乱人伦偷精品免费网站| 久久久久久色| 久久精品国内一区二区三区| 亚洲无亚洲人成网站77777 | 噜噜噜91成人网| 久久黄色网页| 欧美中文字幕| 欧美中文字幕在线播放| 午夜久久久久| 午夜久久99| 欧美综合第一页| 久久精品道一区二区三区| 欧美在线中文字幕| 久久精品av麻豆的观看方式| 久久国产精品久久w女人spa| 欧美一区二区女人| 欧美一区1区三区3区公司| 性18欧美另类| 久久精品人人做人人综合| 久久超碰97中文字幕| 久久精品国产精品亚洲综合 | 欧美96在线丨欧| 欧美高清在线精品一区| 欧美激情一区二区久久久| 欧美女人交a| 欧美无砖砖区免费| 国产精品日本| 国产一区二区日韩精品欧美精品| 国产一区视频在线观看免费| 激情久久久久久久| 亚洲国产第一页| 一本到12不卡视频在线dvd| 亚洲天堂av综合网| 久久成人亚洲| 欧美a级理论片| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲精品乱码| 午夜精彩国产免费不卡不顿大片| 久久成人18免费观看| 男女av一区三区二区色多| 欧美久久久久| 国产毛片一区二区| 亚洲电影激情视频网站| 一本色道久久综合狠狠躁篇的优点 | 日韩午夜激情电影| 亚洲一区黄色| 久久亚洲风情| 国产精品高潮粉嫩av| 国产中文一区二区| 99天天综合性| 久久精品综合一区| 亚洲日本乱码在线观看| 亚洲欧美日韩区| 美女亚洲精品| 国产精品推荐精品| 亚洲欧洲在线看| 午夜视频一区二区| 欧美激情按摩| 亚洲你懂的在线视频| 免费不卡在线视频| 国产日韩欧美综合精品| 亚洲免费电影在线观看| 久久av红桃一区二区小说| 亚洲电影激情视频网站| 亚洲欧美日韩一区二区三区在线观看| 老鸭窝毛片一区二区三区| 国产精品久久久久久妇女6080| 在线不卡亚洲| 午夜一区二区三区不卡视频| 亚洲第一中文字幕| 欧美影院成年免费版| 欧美色精品天天在线观看视频| 激情丁香综合| 欧美在线免费观看亚洲| 亚洲毛片在线| 蜜桃久久精品乱码一区二区| 国产伦精品一区二区三区免费| 9色国产精品| 欧美大片一区二区三区| 亚洲欧美一区二区视频| 欧美日韩国产小视频在线观看| 激情综合在线| 久久久国产成人精品| 亚洲视频观看| 欧美日韩国产综合网 | 亚洲视频播放| 欧美日本一区二区三区| 亚洲激情啪啪| 免费欧美日韩| 久久精品国产v日韩v亚洲| 国产日韩一区二区三区| 亚洲男人的天堂在线观看| 亚洲精品乱码久久久久久| 欧美好骚综合网| 亚洲国产经典视频| 另类av一区二区| 午夜在线a亚洲v天堂网2018| 国产精品乱看| 午夜伦欧美伦电影理论片| 99在线热播精品免费| 欧美日韩亚洲综合一区| 一区二区激情| 99在线视频精品| 国产精品国产三级国产专区53 | 日韩午夜在线电影| 亚洲黄色毛片| 欧美精品一区二区三区四区| 亚洲三级影院| 亚洲人成在线观看网站高清| 欧美激情精品久久久久久大尺度 | 欧美不卡在线| 亚洲日本精品国产第一区| 亚洲国产一区二区三区高清| 欧美激情片在线观看| 宅男66日本亚洲欧美视频| 在线亚洲成人| 国产亚洲一本大道中文在线| 久久人人爽爽爽人久久久| 久久嫩草精品久久久精品| 亚洲黄色天堂| 日韩视频中文字幕| 国产精品美女在线| 久久精品72免费观看| 久久久亚洲影院你懂的| 亚洲理伦电影| 亚洲天堂网站在线观看视频| 国产午夜精品视频免费不卡69堂| 久久久久欧美精品| 欧美激情第3页| 亚洲你懂的在线视频| 欧美在线看片| 亚洲精品乱码久久久久久按摩观 | 久久久综合网| 欧美国产三区| 欧美在线黄色| 欧美高清视频一二三区| 亚洲资源在线观看| 久久精品一区二区| 一区二区三区精品视频在线观看 | 国产精品欧美一区二区三区奶水| 久久久久久婷| 欧美日韩视频一区二区| 久久国产精品久久久久久久久久|