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

C語言 實現(xiàn)歸并排序算法

 更新時間:2016年11月10日 15:31:26   作者:wuyudong  
這篇文章主要介紹了C語言 實現(xiàn)歸并排序算法的相關(guān)資料,需要的朋友可以參考下

C語言 實現(xiàn)歸并排序算法

歸并排序(Merge sort)是創(chuàng)建在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個非常典型的應(yīng)用。

一個歸并排序的例子:對一個隨機點的鏈表進行排序

算法描述

歸并操作的過程如下:

  1. 申請空間,使其大小為兩個已經(jīng)排序序列之和,該空間用來存放合并后的序列
  2. 設(shè)定兩個指針,最初位置分別為兩個已經(jīng)排序序列的起始位置
  3. 比較兩個指針所指向的元素,選擇相對小的元素放入到合并空間,并移動指針到下一位置
  4. 重復(fù)步驟3直到某一指針到達序列尾
  5. 將另一序列剩下的所有元素直接復(fù)制到合并序列尾

特點:歸并排序是穩(wěn)定的排序.即相等的元素的順序不會改變,  速度僅次于快速排序,但較穩(wěn)定。

歸并操作

歸并操作(merge),也叫歸并算法,指的是將兩個順序序列合并成一個順序序列的方法。

如:設(shè)有數(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)

// Completed on 2014.10.11 17:20
// Language: C99
//
// 版權(quán)所有(C)codingwu  (mail: oskernel@126.com) 
// 博客地址:http://www.cnblogs.com/archimedes/
#include<stdio.h>
#include<stdlib.h>void merge_sort(int *list, const int first, const int last)
{
  int len= last-first+1; 
  int left_min,left_max;  //左半?yún)^(qū)域邊界 
  int right_min,right_max; //右半?yún)^(qū)域邊界 
  int index;
  int i;
  int *tmp;
  tmp = (int *)malloc(sizeof(int)*len);
  if( tmp == NULL || len <= 0 )
    return;
  
  for( i = 1; i < len; i *= 2 )
  {
    for( left_min = 0; left_min < len - i; left_min = right_max)
    {
      int j;
      right_min = left_max = left_min + i;
      right_max = left_max + i;
      j = left_min;
      if ( right_max > len )
        right_max = len;
      index = 0;
      while( left_min < left_max && right_min < right_max )
      {
        tmp[index++] = (list[left_min] > list[right_min] ? list[right_min++] : list[left_min++]);
      }
      while( left_min < left_max )
      {
        list[--right_min] = list[--left_max];
      }
      while( index > 0 )
      {
        list[--right_min] = tmp[--index];
      }
    }
  }
  free(tmp);
}
int main()
{
  int a[] = {288, 52, 123, 30, 212, 23, 10, 233};
  int n, mid;
  n = sizeof(a) / sizeof(a[0]);
  mid = n / 2;
  merge_sort(a, 0, n - 1);
  for(int k = 0; k < n; k++)
    printf("%d ", a[k]);
  printf("\n");
  return 0;
}

使用遞歸實現(xiàn):

// Completed on 2014.10.11 18:20
// Language: C99
//
// 版權(quán)所有(C)codingwu  (mail: oskernel@126.com) 
// 博客地址:http://www.cnblogs.com/archimedes/
#include<stdio.h>
#include<stdlib.h>
void merge(int *array,const int first, const int mid, const int last)
{
  int i,index;
  int first1,last1;
  int first2,last2;
  int *tmp;
  tmp = (int *)malloc((last-first+1)*sizeof(int));
  if( tmp == NULL )
    return;
  first1 = first;
  last1 = mid;
  first2 = mid+1;
  last2 = last;
  index = 0;
  while( (first1 <= last1) && (first2 <= last2) )
  {
    if( array[first1] < array[first2] )
    {
      tmp[index++] = array[first1];
      first1++;
    }
    else{
      tmp[index++] = array[first2];
      first2++;
    }
  }
  while( first1 <= last1 )
  {
    tmp[index++] = array[first1++];
  }
  while( first2 <= last2 )
  {
    tmp[index++] = array[first2++];
  }
  for( i=0; i<(last-first+1); i++)
  {
    array[first+i] = tmp[i];
  }
  free(tmp);
}
void merge_sort(int *array, const int first, const int last)
{
  int mid = 0;
  if(first < last)
  {
    mid = (first + last) / 2;
    merge_sort(array, first, mid);
    merge_sort(array, mid + 1, last);
    merge(array, first, mid, last);
  }
}
int main()
{
  int a[] = {288, 52, 123, 30, 212, 23, 10, 233};
  int n, mid;
  n = sizeof(a) / sizeof(a[0]);
  mid = n / 2;
  merge_sort(a, 0, n - 1);
  for(int k = 0; k < n; k++)
    printf("%d ", a[k]);
  printf("\n");
  return 0;
}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • C++中關(guān)于Crt的內(nèi)存泄漏檢測的分析介紹

    C++中關(guān)于Crt的內(nèi)存泄漏檢測的分析介紹

    本篇文章介紹了,在C++中關(guān)于Crt的內(nèi)存泄漏檢測的分析說明。需要的朋友參考下
    2013-04-04
  • c++回調(diào)之利用sink示例

    c++回調(diào)之利用sink示例

    Sink的本質(zhì)是利用C++的封裝、繼承、多態(tài)的面向?qū)ο髞韺崿F(xiàn),從實現(xiàn)角度來說,更優(yōu)于函數(shù)指針回調(diào),下面是示例
    2014-04-04
  • 求子數(shù)組最大和的實例代碼

    求子數(shù)組最大和的實例代碼

    求子數(shù)組最大和的實例代碼,需要的朋友可以參考一下
    2013-03-03
  • c++ 如何合并兩個有序鏈表

    c++ 如何合并兩個有序鏈表

    這篇文章主要介紹了c++ 如何合并兩個有序鏈表,幫助大家更好的理解和學習C++,感興趣的朋友可以了解下
    2020-08-08
  • C語言memset函數(shù)使用方法詳解

    C語言memset函數(shù)使用方法詳解

    這篇文章主要介紹了C語言memset函數(shù)使用方法詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家掌握這樣的方法,需要的朋友可以參考下
    2017-10-10
  • 基于C語言實現(xiàn)簡單的五子棋游戲

    基于C語言實現(xiàn)簡單的五子棋游戲

    這篇文章主要為大家詳細介紹了基于C語言實現(xiàn)簡單的五子棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C語言版三子棋游戲?qū)崿F(xiàn)代碼

    C語言版三子棋游戲?qū)崿F(xiàn)代碼

    這篇文章主要為大家詳細介紹了C語言版三子棋游戲的實現(xiàn)代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • C語言編程時常犯十八個錯誤小結(jié)

    C語言編程時常犯十八個錯誤小結(jié)

    C語言的最大特點是:功能強、使用方便靈活。C編譯的程序?qū)φZ法檢查并不象其它高級語言那么嚴格,這就給編程人員留下“靈活的余地”,但還是由于這個靈活給程序的調(diào)試帶來了許多不便,尤其對初學C語言的人來說,經(jīng)常會出一些連自己都不知道錯在哪里的錯誤
    2013-07-07
  • 詳解C++11原子類型與原子操作

    詳解C++11原子類型與原子操作

    這篇文章主要介紹了C++11原子類型與原子操作的相關(guān)資料,幫助大家更好的理解和學習c++,感興趣的朋友可以了解下
    2020-08-08
  • 關(guān)于C++對象繼承中的內(nèi)存布局示例詳解

    關(guān)于C++對象繼承中的內(nèi)存布局示例詳解

    這篇文章主要給大家介紹了關(guān)于C++對象繼承中內(nèi)存布局的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面跟著小編來一起學習學習吧。
    2017-08-08

最新評論