欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)歸并排序

 更新時間:2020年03月20日 07:47:14   作者:EggyGeDan  
這篇文章主要為大家詳細介紹了C++實現(xiàn)歸并排序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

定義:歸并排序(MERGE-SORT)是建立在歸并操作上的一種有效的排序算法,該算法是采用分治法(Divide and Conquer)的一個非常典型的應用。將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。若將兩個有序表合并成一個有序表,稱為二路歸并。

簡單的來說,歸并排序主要分為三步,一是對數(shù)組的劃分,二是對數(shù)組的排序,三是對數(shù)組的合并。劃分的大小是可以隨自己的想法而設置,但是一般都是以2為單位,這樣最小的一組的排序就比較方便。

具體一個簡單的例子:

設有數(shù)列{6,202,100,301,38,8,1}

初始狀態(tài):6,202,100,301,38,8,1

第一次歸并后:{6,202},{100,301},{8,38},{1},比較次數(shù):3;

第二次歸并后:{6,100,202,301},{1,8,38},比較次數(shù):4;

第三次歸并后:{1,6,8,38,100,202,301},比較次數(shù):4;

總的比較次數(shù)為:3+4+4=11;

逆序數(shù)為14;

在利用算法實現(xiàn)的時候,需要利用遞歸的思想,函數(shù)的入口是整個數(shù)組,不斷進行劃分,直到劃分的數(shù)組只剩下一個或兩個元素為止,對這一組進行排序后,再按原來劃分的大小還原并排序,這里利用一個新的數(shù)組比較方便,將兩個排序后的數(shù)組,再從小到大一個一個放入新的數(shù)組。

具體代碼:

#include<iostream>
#include<algorithm>
using namespace std;
 
void merge(int *data,int start,int end,int *result) 
{
  int left_length = (end - start + 1) / 2 + 1;  
  int left_index = start;
  int right_index = start + left_length;
  int result_index = start;
  while(left_index<start + left_length && right_index <end + 1) //store data into new array
  {
    if(data[left_index] <= data[right_index])
      result[result_index++] = data[left_index++];
    else
      result[result_index++] = data[right_index++];
  }
  while(left_index < start + left_length)
    result[result_index++] = data[left_index++];
  while(right_index <end+1)
    result[result_index++] = data[right_index++];
}
 
void merge_sort(int *data,int start,int end,int *result)
{
  if(1 == end - start)  //last only two elements
  {
    if(data[start] > data[end])
    {
      int temp = data[start];
      data[start] = data[end];
      data[end] = temp;
    }
    return;
  }
  else if (end == start)
    return; //last one element then there is no need to sort;
  else{
    //continue to divide the interval
    merge_sort(data, start, (end - start + 1) / 2 + start, result);
    merge_sort(data, (end - start + 1) / 2 + start + 1, end, result);
    //start to merge sorted data
    merge(data, start, end, result);
    for (int i = start; i <= end;++i)
    {
      data[i] = result[i];
    }
  }
 
}
//example
int main()
{
  int data[] = {5,3,6,7,3,2,7,9,8,6,34,32,5,4,43,12,37};
  int length = 17;
  int result[length];
  cout << "before sorted:"<<'\n';
  for (int i = 0; i < length;i++)
    cout << data[i]<<' ';
  cout << '\n'
     << "after sorted:"<<'\n';
  merge_sort(data, 0, length - 1, result);
  for (int i = 0; i < length;i++)
    cout << result[i]<<' ';
  return 0;
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C++實現(xiàn)LeetCode(164.求最大間距)

    C++實現(xiàn)LeetCode(164.求最大間距)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(164.求最大間距),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-07-07
  • C語言變量類型的深入分析

    C語言變量類型的深入分析

    這篇文章主要介紹了C語言變量類型的深入分析的相關資料,需要的朋友可以參考下
    2017-07-07
  • 基于C語言實現(xiàn)簡單的12306火車售票系統(tǒng)

    基于C語言實現(xiàn)簡單的12306火車售票系統(tǒng)

    火車售票系統(tǒng)給我們的出行帶來了極大的方面,那么他基于編程是如何實現(xiàn)的呢?今天小編抽時間給大家分享一個使用C語言寫的一個簡單的火車票系統(tǒng),感興趣的朋友參考下
    2016-09-09
  • C語言簡易掃雷游戲

    C語言簡易掃雷游戲

    這篇文章主要為大家詳細介紹了C語言簡易掃雷游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Qt中connect()函數(shù)及用法詳解

    Qt中connect()函數(shù)及用法詳解

    connect() 函數(shù)就是Qt 框架中用于將信號(SIGNAL)和槽(SLOT)關聯(lián)起來的核心函數(shù),本文給大家介紹Qt中connect()函數(shù),感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • 劍指offer之C++語言實現(xiàn)鏈表(兩種刪除節(jié)點方式)

    劍指offer之C++語言實現(xiàn)鏈表(兩種刪除節(jié)點方式)

    今天小編就為大家分享一篇關于劍指offer之C++語言實現(xiàn)鏈表(兩種刪除節(jié)點方式),小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • C語言課程設計之停車場管理問題

    C語言課程設計之停車場管理問題

    這篇文章主要為大家詳細介紹了C語言課程設計之停車場管理問題,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 淺談char*類型返回值和字符串常量

    淺談char*類型返回值和字符串常量

    下面小編就為大家?guī)硪黄獪\談char*類型返回值和字符串常量。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • C語言修煉之路一朝函數(shù)思習得?模塊思維世間生下篇

    C語言修煉之路一朝函數(shù)思習得?模塊思維世間生下篇

    函數(shù)是一組一起執(zhí)行一個任務的語句。每個?C?程序都至少有一個函數(shù),即主函數(shù)?main()?,所有簡單的程序都可以定義其他額外的函數(shù)
    2022-03-03
  • C++Stack棧類模版實例詳解

    C++Stack棧類模版實例詳解

    這篇文章主要為大家詳細介紹了C++Stack棧類模版實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02

最新評論