文章目录

  • 一、问题
  • 二、解析
  • 三、设计
  • 四、分析
  • 五、代码

一、问题

二分归并排序:对n个不同的数构成的数组A[1…n]进行排序,其中n=2^k

二、解析

二分归并排序是一种很经典的分治思想的排序算法,过程可以分为二分分解和归并两个过程:

二分:为了让一个长序列有序,可以将长序列从中间拆分成两个子序列,让两个子序列有序,两个子序列又可以单独看成一个长序列,每个都可以继续分成两个子序列,以此类推,不断用同一个规则缩小子序列的长度,直到最后子序列只有两个数时进行比较排序,使其有序;

归并:回溯上一个拆分的过程,把有序的两个子序列合并,使合并时的序列也有序,以此类推,直到最原始的长序列有序,每一个归并的过程都是一次独立的归并排序,但是因为序列整体偏有序,所以二分归并比直接归并的操作次数要少。

三、设计

代码实现可以直接一点,把分解的过程简化了,直接把两个相邻数字为一组看成最后分出的子序列,进行有序归并,所以n个元素可以形成floor(n/2)个序列,然后再次归并,形成floor(n/4)个序列,以此类推,直到所有元素排序完毕;

四、分析

时间复杂度W(n)=2W(n/2)+n-1;W(1)=0;故W(1)=nlogn-n+1;

五、代码

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<time.h>
#include<cstdlib>
using namespace std;
const int N = 5;
void Random(int a[],int n)//随机生成乱序数组
{  srand( (unsigned)time( NULL )); for(int i=0;i<=n;i++){a[i]=rand()%1000;//%1000取1000以内的数}
} void merge(int *a, int left, int mid, int right) //归并算法
{  int k, begin1, begin2, end1, end2;begin1 = left;  end1 = mid;  begin2 = mid + 1;  end2 = right;  int *temp = (int *)malloc((right - left + 1) * sizeof(int));  for(k = 0; begin1 <= end1 && begin2 <= end2; k++) //自小到大排序  {  if(a[begin1] <= a[begin2])  temp[k] = a[begin1++];  else  temp[k] = a[begin2++];  }  if(begin1 <= end1) //左剩  memcpy(temp + k, a + begin1, (end1 - begin1 + 1) * sizeof(int));  else //右剩  memcpy(temp + k, a + begin2, (end2 - begin2 + 1) * sizeof(int));  memcpy(a + left, temp, (right - left + 1) * sizeof(int)); //排序后复制到原数组  free(temp); //释放空间
}
void merge_sort(int *a, unsigned int begin, unsigned int end)
{  int mid;  if(begin < end)  {   mid = (end + begin) / 2; merge_sort(a, begin, mid); //分治  merge_sort(a, mid + 1, end); //分治  merge(a, begin, mid, end);  //合并两个已排序的数列  }
}
int main()
{  int a[N];  Random(a,N);  for(int i=0;i<N;i++)  {  cout<<a[i]<<" ";  }  cout << endl;merge_sort(a, 0, N-1);  for(int i=0;i<N;i++)  {  cout<<a[i]<<" ";  }cout << endl;system("pause");return 0;
}

算法分析与设计——二分归并算法相关推荐

  1. 二分归并算法实验报告

    实验报告 课程名称 <算法分析与设计> 实验日期 2020 年 2 月 25日 至 2020年 3 月 3 日 学生姓名 戴昊宇 所在班级 计算机184 学号 2018212212015 ...

  2. 算法分析与设计 二分查找

    算法分析与设计 二分查找 二分查找的基本概念 ​ 二分查找是一种在有序数组中查找某一特定元素的查找算法.这种查找方法将查找的时间复杂度从原本的线性时间提升到了对数时间范围,大大缩短了搜索时间. ​ 二 ...

  3. 算法分析与设计:贪心算法实现最少硬币找钱问题(支付+找零共花费硬币数最少)

    硬币找钱问题 Problem Description 设有六种不同面值的硬币,各硬币的面值分别为 5分,1角,2角,5角,1元,2元.现要用这些面值的硬币来购物和找钱.购物时可以使用的各面值的硬币个数 ...

  4. 【算法分析与设计】基本算法设计方法的思想策略

    重要的算法问题类型 查找问题 排序问题 图问题 组合问题 几何问题 思想1:分治法 基本思想:把一个规模为 n n n的问题分解为两个或者多个较小的.与原问题类型相同的子问题,再对子问题求解,然后把子 ...

  5. 【算法分析与设计】排序算法的时间复杂度与O(NlogN)

    Q:基于比较的内排序算法能不能比 O ( N log ⁡ N ) O(N\log{N}) O(NlogN)

  6. 【算法分析与设计】内排序算法归纳

    排序算法 排序综述 排序的基本概念 排序算法的性能 时间性能 空间性能 排序类的定义 各种基本排序算法的比较 时间复杂度 空间复杂度 稳定性 算法简单性 待排序的记录个数 记录本身信息量的大小 初始记 ...

  7. 【算法分析与设计】浅析算法复杂度

    文章目录 算法复杂度 算法复杂度的求和计算方法 递归算法复杂度的计算方法 证明斐波那契数列递归求解复杂度 算法复杂度 算法复杂度可以用 O ( T ( n ) ) O(T(n)) O(T(n)

  8. 计算机算法分析与设计(基本算法框架)

    一.分治法 将一个大的问题分解成若干个小问题 对各个小问题逐一击破 将子问题的解决结果合并,得到问题的解 例子 合并排序 棋盘覆盖问题 循环赛日程表 二.分枝限界法(广度优先搜索) 从根节点开始节点扩 ...

  9. 【算法分析与设计】回溯算法解决七巧板着色问题

    文章目录 四色定理 七巧板 功能需求 程序设计 编程实现 四色定理 四色定理是一种关于地图着色的定理,指出任何平面地图都可以只用四种颜色进行着色,使得相邻的区域颜色不同. 简单来说,这个定理表明,如果 ...

最新文章

  1. Git Manual / Git使用手册 / Git, GitLab, Git Bash, TortoiseGit (建议全文复制到Word文档中通过导航窗格查看)...
  2. DirectFB编译环境
  3. module 'tensorflow' has no attribute 'Session'
  4. 不需要网络的调频收音机_测试工程师真的不需要懂网络知识么?
  5. 高等数学上-赵立军-北京大学出版社-题解-练习4.5
  6. 自定义相册、九宫格显示图片
  7. 谷歌浏览器外贸版_外贸 网站移动端优化 浅析
  8. Nginx - 配置
  9. [唐胡璐]QTP框架 - 关键字驱动测试框架之三 - 对象库管理
  10. vim的几个常用操作
  11. Spring Boot为什么不需要额外安装Tomcat?
  12. KEIL编程中如何重定义printf()函数,以便在后来的开发中使用此函数进行串口数据输出
  13. 三角网导线平差实例_导线平差自动计算表(非常实用)
  14. 【源码解析】StyleNeRF 之Train_encoder.py
  15. 6翻了 (15 分)
  16. C语言之——自定义数据类型
  17. 数据处理取对数的作用
  18. Tuxera NTFS2022Mac如何安装以及怎么激活NTFS?
  19. 阿里、华为领跑2019中国公有云物联网平台
  20. 经验之谈 | 如何从零开始构建深度学习项目?

热门文章

  1. python免杀基础——三步(查杀、连接、代码)情况
  2. VS2008 SP1制作安装程序离线安装.Net Framework3.5
  3. 欧几里得空间 希尔伯特空间
  4. 提示工程师:如何高效的向ChatGPT提问对话
  5. 学编程买什么电脑最好
  6. 中国纸浆制造行业产销需求与前景规模分析报告2022-2028年版
  7. 隔空投送怎么打开「详细教程」
  8. 运用 iMazing备份《保卫萝卜》游戏存档
  9. 一套自生成组件系统的构想与实践
  10. 5分钟理解贝叶斯公式