中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

【數(shù)據(jù)結(jié)構(gòu)】常見(jiàn)的7種比較排序算法1-創(chuàng)新互聯(lián)

● 直接插入排序(Insert Sort)

為企業(yè)提供成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、網(wǎng)站優(yōu)化、成都全網(wǎng)營(yíng)銷(xiāo)推廣、競(jìng)價(jià)托管、品牌運(yùn)營(yíng)等營(yíng)銷(xiāo)獲客服務(wù)。創(chuàng)新互聯(lián)公司擁有網(wǎng)絡(luò)營(yíng)銷(xiāo)運(yùn)營(yíng)團(tuán)隊(duì),以豐富的互聯(lián)網(wǎng)營(yíng)銷(xiāo)經(jīng)驗(yàn)助力企業(yè)精準(zhǔn)獲客,真正落地解決中小企業(yè)營(yíng)銷(xiāo)獲客難題,做到“讓獲客更簡(jiǎn)單”。自創(chuàng)立至今,成功用技術(shù)實(shí)力解決了企業(yè)“網(wǎng)站建設(shè)、網(wǎng)絡(luò)品牌塑造、網(wǎng)絡(luò)營(yíng)銷(xiāo)”三大難題,同時(shí)降低了營(yíng)銷(xiāo)成本,提高了有效客戶轉(zhuǎn)化率,獲得了眾多企業(yè)客戶的高度認(rèn)可!

1、算法描述:

  該算法是一種簡(jiǎn)單直觀的是通過(guò)構(gòu)建有序序列,對(duì)于未排序數(shù)據(jù),在已排序序列中從后向前掃描,找到相應(yīng)位置并插入。插入排序在實(shí)現(xiàn)上只需用到O(1)的額外空間的排序,因而在從后向前掃描過(guò)程中,需要反復(fù)把已排序元素逐步向后挪位為最新元素提供插入空間。

2、步驟:

1)從第一個(gè)元素開(kāi)始,該元素可以認(rèn)為已經(jīng)被排序

2)取出下一個(gè)元素,在已經(jīng)排序的元素序列中從后向前掃描

3)如果該元素(已排序)大于新元素,將該元素移到下一位置

4)重復(fù)步驟3,直到找到已排序的元素小于或者等于新元素的位置

5)將新元素插入到該位置中

6)重復(fù)步驟2

  插入排序在對(duì)幾乎已經(jīng)排好序的數(shù)據(jù)操作時(shí),效率高,即可以達(dá)到線性排序的效率,但插入排序一般來(lái)說(shuō)是低效的, 因?yàn)椴迦肱判蛎看沃荒軐?shù)據(jù)移動(dòng)一位。

具體實(shí)現(xiàn)如下:

void InsertSort(int *arr, size_t size)//直接插入排序
{
 assert(arr);
 for (size_t i = 0; i < size - 1; ++i)
 {
  int end = i;
  int tmp = arr[i + 1];//tmp取出要插入的元素(下一個(gè)元素)
  while (end >= 0 && arr[end] > tmp)//end要大于等于0
  {
   arr[end + 1] = arr[end];//大于tmp的數(shù)后移
   --end;
  }
  arr[end + 1] = tmp;
 }
}

● 希爾排序(Shell Sort)

1、算法描述:

  希爾排序,也稱遞減增量排序算法,是插入排序的一種高速而穩(wěn)定的改進(jìn)版本。希爾排序是基于插入排序而提出改進(jìn)方法的。設(shè)置增量為gap=size/3+1,在gap不為1時(shí),希爾排序是在進(jìn)行預(yù)排序,在gap==1時(shí),進(jìn)行插入排序時(shí),可提高效率。

2、步驟:

1)設(shè)置增量gap為size

2)使gap=gap/3+1,同時(shí)對(duì)所有組進(jìn)行插入排序,直到size-gap-1時(shí),表示所有組已經(jīng)排序完成

3)重復(fù)步驟2,直到gap為1時(shí)停止

【數(shù)據(jù)結(jié)構(gòu)】常見(jiàn)的7種比較排序算法1

具體實(shí)現(xiàn)如下:

void ShellSort(int *arr, size_t size)//希爾排序
{
 assert(arr);
 int gap = size;//gap設(shè)置插入排序區(qū)間
 while (gap > 1)
 {
  gap = gap / 3 + 1;//防止gap為2時(shí),下一次gap為1,使得最后一次的gap為1
  //例如(2 5 4 9 3 6 8 7 1)使多組同時(shí)進(jìn)行直接插入排序
  for (size_t i = 0; i < size - gap; ++i)
  {
   int end = i;
   int tmp = arr[i + gap];
   while (end >= 0 && arr[end] > tmp)
   {
    arr[end + gap] = arr[end];
    end -= gap;
   }
   arr[end + gap] = tmp;
  }
 }
}

● 選擇排序(Select Sort)

1、算法描述:

  首先在未排序序列中找到最小和大元素,存放到排序序列的兩端,然后,再?gòu)氖S辔磁判蛟刂欣^續(xù)尋找最小和大元素,然后放到排序序列(該序列縮短了2個(gè)元素,不包含原序列的兩端)兩端。以此類推,直到所有元素均排序完畢。

2、步驟:

1)一重循環(huán):通過(guò)i和size控制進(jìn)行尋找最小和大元素的區(qū)間

2)使min為區(qū)間的首位元素位置,max為區(qū)間的末尾元素位置

3) 二重循環(huán):從序列中尋找最小和大元素,注意在進(jìn)行不斷比較過(guò)程中進(jìn)行交換,不能在找到的它們的下標(biāo)后才進(jìn)行交換。

具體實(shí)現(xiàn)如下:

void SelectSort(int *arr, size_t size)
{
 int min, max;
 for (size_t i = 0; i < size; ++i, --size)
 {
  min = i;
  max = size - 1;//max為當(dāng)前選擇排序段的最后一個(gè)數(shù)據(jù)
  //max = size - 1 - i時(shí):注意不能用size進(jìn)行減1,防止max=size-i-i中size的改變,重新定義len進(jìn)行變化
  for (int j = i; j <= max; ++j)
  {
   if (arr[j] < arr[min])
   {
    swap(arr[j], arr[min]);
   }
   if (arr[j] > arr[max])
   {
    swap(arr[j], arr[max]);
   }
  }
 }
}

● 堆排序(Heap Sort)

1、算法描述:

  堆積排序(Heapsort)是指利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計(jì)的一種排序算法。堆是一個(gè)近似完全二叉樹(shù)的結(jié)構(gòu),并同時(shí)滿足堆性質(zhì):即子結(jié)點(diǎn)的鍵值或索引總是小于(或者大于)它的父節(jié)點(diǎn)。

  升序序列的實(shí)現(xiàn)需要建立大堆,降序序列的實(shí)現(xiàn)需要建立小堆。下面對(duì)升序序列的實(shí)現(xiàn)進(jìn)行分析。

2、步驟:

1)大堆的建立:通過(guò)下調(diào)建立大堆,先比較左右子結(jié)點(diǎn)的大小,使child指向較大數(shù),再比較父親結(jié)點(diǎn)的child所指數(shù)據(jù)的大小,小于孩子結(jié)點(diǎn)就進(jìn)行交換。

2)每次使堆的左右子樹(shù)為大堆,故從下向上進(jìn)行大堆的建立

3)交換堆頂元素的堆的最后一個(gè)元素,然后重新使堆(不包含最后一個(gè)元素)成為大堆

4)重復(fù)步驟3,直到堆中只有一個(gè)元素為止

具體實(shí)現(xiàn)如下:

void AdjustDown(int* arr, size_t parent, size_t size)//建大堆(每次選出大的放在后面)
{
 size_t child = 2 * parent + 1;
 while (child < size)
 {
  if (child + 1 < size && arr[child + 1] > arr[child])
  {
   ++child;
  }
  if (arr[child] > arr[parent])
  {
   swap(arr[child], arr[parent]);
   parent = child;
   child = 2 * parent + 1;
  }
  else
  {
   break;
  }
 }
}
void HeapSort(int *arr, size_t size)//升序(大堆),降序(小堆)
{
 assert(arr);
 for (int i = (size - 2) / 2; i >= 0; --i)//注意邊界條件,i>=0和i=(size-2)/2
 {
  AdjustDown(arr, i, size);
 }
 for (size_t i = 0; i < size; ++i)
 {
  swap(arr[0], arr[size - 1 - i]);//交換,使大數(shù)放在堆的最后
  AdjustDown(arr, 0, size - 1 - i);
 }
}

● 冒泡排序(Bubble Sort)

1、算法描述:

  重復(fù)地走訪過(guò)要排序的數(shù)列,一次比較兩個(gè)元素,如果他們的順序錯(cuò)誤(升序的)就把他們交換過(guò)來(lái)。走訪數(shù)列的工作是重復(fù)地進(jìn)行直到?jīng)]有再需要交換(flag==0),也就是說(shuō)該數(shù)列已經(jīng)排序完成。該算法是越小的元素會(huì)經(jīng)由交換慢慢“浮”到數(shù)列的頂端。

2、步驟:

1)設(shè)置標(biāo)志flag。

2)從開(kāi)始第一對(duì)到結(jié)尾的最后一對(duì),比較相鄰的元素。如果第一個(gè)比第二個(gè)大,就交換他們兩個(gè)。

3)如果flag==0,則在進(jìn)行一趟比較后沒(méi)有發(fā)生交換,則序列已經(jīng)有序了。

4)持續(xù)每次對(duì)越來(lái)越少的元素重復(fù)步驟2、3,總共進(jìn)行了size-1趟。

具體實(shí)現(xiàn)如下:

void BubbleSort(int *arr, size_t size)//冒泡排序,依次將大數(shù)據(jù)存放在后面
{
 assert(arr);
 int flag = 0;//標(biāo)志位判斷數(shù)組是否接近有序
 for (size_t i = 0; i < size - 1; ++i)//進(jìn)行了size-1趟冒泡
 {
  for (size_t j = 0; j < size - i - 1; ++j)//進(jìn)行比較,交換
  {
   if (arr[j] > arr[j + 1])
   {
    swap(arr[j], arr[j + 1]);
    flag = 1;
   }
  }
  if (flag == 0)//一趟結(jié)束后沒(méi)有一次交換,跳出循環(huán)
  {
   break;
  }
 }
}

其余比較排序算法的實(shí)現(xiàn)見(jiàn)博主的下一篇博文

創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國(guó)云服務(wù)器,動(dòng)態(tài)BGP最優(yōu)骨干路由自動(dòng)選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動(dòng)現(xiàn)已開(kāi)啟,新人活動(dòng)云服務(wù)器買(mǎi)多久送多久。

文章標(biāo)題:【數(shù)據(jù)結(jié)構(gòu)】常見(jiàn)的7種比較排序算法1-創(chuàng)新互聯(lián)
URL分享:http://m.rwnh.cn/article8/djipop.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、網(wǎng)站內(nèi)鏈、小程序開(kāi)發(fā)、網(wǎng)站策劃網(wǎng)站建設(shè)、網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
信丰县| 曲麻莱县| 醴陵市| 剑阁县| 长葛市| 读书| 惠来县| 方城县| 巴东县| 福鼎市| 陇川县| 淳化县| 秭归县| 砚山县| 临城县| 全州县| 乌鲁木齐县| 察雅县| 景谷| 顺平县| 平泉县| 元氏县| 新乡市| 永城市| 大新县| 乐至县| 丰台区| 柳州市| 麟游县| 襄城县| 贺州市| 彰武县| 新龙县| 江津市| 梁平县| 镇宁| 大同县| 浦江县| 永丰县| 邢台县| 贵溪市|