久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2072|回復: 0
打印 上一主題 下一主題
收起左側

C語言分治排序算法

[復制鏈接]
跳轉到指定樓層
樓主
ID:280163 發表于 2018-1-27 11:58 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
分治排序算法
  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<math.h>

  4. /*將A數組中p到r元素進行分治排序*/
  5. MERGE(int *A, int p, int q, int r)
  6. {
  7.         int n1 = q - p + 1;//數組L中元素個數
  8.         int n2 = r - q;//數組R中元素個數
  9.         int *L, *R;
  10.         int i;
  11.         int j;
  12.         int k;
  13.         L = malloc( ( n1 + 1 ) * sizeof( int ) );
  14.         R = malloc( ( n2 + 1 ) * sizeof( int ) );

  15.         for( i = 0; i < n1; i++ )
  16.         {
  17.                 *( L + i ) = *( A + p + i );//A[p]到A[q]
  18.         }

  19.         for( i = 0; i < n2; i++ )
  20.         {
  21.                 *( R + i ) = *( A + q + i + 1 );//A[q+1]到A[r]
  22.         }

  23.         L[n1] = 2147483647;//2^31-1
  24.         R[n2] = 2147483647;//2^31-1

  25.         i=0;
  26.         j=0;

  27.         for( k = p; k <= r; k++ )
  28.         {
  29.                 if( L[i] <= R[j] )
  30.                 {
  31.                         A[k] = L[i];
  32.                         i = i + 1;
  33.                 }
  34.                 else
  35.                 {
  36.                         A[k] = R[j];
  37.                         j = j + 1;
  38.                 }
  39.         }

  40.         free( L );
  41.         free( R );
  42. }

  43. MERGE_SORT( int *A, int p, int r )
  44. {
  45.         int q;
  46.         if( p < r )
  47.         {
  48.                 q = ( int )floor( ( p + r ) / 2 );
  49.                 MERGE_SORT( A , p , q );
  50.                 MERGE_SORT( A , q+1 , r );
  51.                 MERGE( A , p , q , r );
  52.         }
  53. }

  54. main()
  55. {
  56.         int i;
  57.         int x[100];

  58.         for( i = 0; i < 10; i++ )
  59.         {
  60.                 x[i] = rand() % 100;
  61.                 printf("x[%d] = %d\n", i, x[i] );
  62.         }

  63.         MERGE_SORT( x , 0 , 9 );

  64.         for( i = 0; i < 10; i++ )
  65.         {
  66.                 printf("x[%d] = %d\n", i, x[i] );
  67.         }

  68.     getch();
  69. }
復制代碼


分治排序.rar

656 Bytes, 下載次數: 4, 下載積分: 黑幣 -5

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 最近中文字幕在线视频1 | 一区二区中文 | 爱爱视频日本 | 成年人在线观看 | 日韩中文字幕视频 | 久夜精品 | 亚洲免费精品 | 亚洲国产网站 | 麻豆精品久久久 | 国产日韩一区 | 久久免费福利 | 成人蜜桃av| 精品国产乱码一区二区三区 | 女同久久另类99精品国产 | 国产日韩欧美综合 | 精品国产视频 | 亚洲精品一区中文字幕乱码 | 亚洲a一区 | 国产小视频在线观看 | 午夜成人免费视频 | 亚洲精品乱码久久久久久按摩观 | 国产综合精品 | 午夜欧美一区二区三区在线播放 | 欧美一区二区三区的 | 黄色在线观看网站 | 日本一二三区在线观看 | 特黄特黄a级毛片免费专区 av网站免费在线观看 | 一区二区三区中文字幕 | 皇色视频在线 | 97超碰成人 | 福利在线看 | 国产精品特级片 | 久久69精品久久久久久久电影好 | 欧美理论在线观看 | 天天射天天操天天干 | 9999精品视频 | 少妇性l交大片免费一 | 日韩一区二区三区在线 | 成人三级在线播放 | 精品视频一区二区三区四区 | 久久久久久久久久性 |