浅谈分治策略之一:归并排序

分治策略是对大型问题的一种有效的方法,将一些大规模问题转换为一些小规模问题,分而治之,之前我们讲过了插入排序,插入排序是一种增量方法,当程序规模扩大时效率将下降,这时候我们可以采取分治的方法,本系列讲以归并排序为引子,来详细为大家讲解一下分治法。

(一)递归算法结构解决分治问题

分治法的思想是将几个规模大的问题转化为一些小规模的子问题,合理利用递归可以求解这些子问题。最后合并这些子问题。

(二)分治模式在递归时对的三个步骤

分解

解决

合并

归并排序

分解

解决

合并

具体问题我们可以利用归并排序的问题来讲解一下

还是利用扑克牌的思想,我们面前现在有两堆排好序的扑克牌,面朝上,最小的在上,现在把两堆牌合并,并排好序,牌面向下的放在桌子上。基本步骤就是从两堆牌选出最小的牌,然后按顺序排列,面朝下的放在桌面上重新组成一副牌。下面我们用代码实现。

我们需要建立两个函数,归并函数,归并排序函数。

首先,我们先结果归并的函数:

void merge(int *a,int p,int q,int r)

{

int *tmp = new int[r - p + 1];

int i = p;

int j = q +1;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值