24小时热门版块排行榜    

查看: 516  |  回复: 3

冰雨hust

铁虫 (小有名气)

[求助] 归并中的递归问题

对于归并排序中
void mergeSort(int a,int b)
{
if(a<b)
{
int mid=(a+b)/2;--------(1)
mergeSort(a,mid);---------(2)
mergeSort(mid+1,b);--------(3)
merge(a,mid,b);--------(4)

}
}
这个程序的执行过程是咋样的啊,执行到(2)时要用自身的函数,递归调用,是不是一直递归调用到递归结束,再执行(3),又继续递归调用,直到结束,再执行(4),程序结束啊?各位大侠指点下啊~~~
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
jjdg: 金币+2, 感谢参与 2013-06-27 00:34:16
递归的问题,你要抽象出来"自相似结构"部分.不要管他怎么又调用自身,只分析步骤即可.

简单来说,mergeSort(a,b)是这样一个函数,实现对于a到b之间的元素进行归并排序(a<b)
具体步骤是:
找到中点mid,
用同样的办法(归并排序)a到mid得到排好序的序列A
用同样的办法(归并排序)mid+1到b得到排好序的序列B
合并序列A和B得到完整的排序序列C(C=A U B,但是是排好序的)
--------
一般会设置递归出口,上面的函数隐含了出口(就是a<b),当a==b或者a>b时会直接返回.
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2013-06-26 20:47:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

冰雨hust

铁虫 (小有名气)

引用回帖:
2楼: Originally posted by libralibra at 2013-06-26 20:47:59
递归的问题,你要抽象出来"自相似结构"部分.不要管他怎么又调用自身,只分析步骤即可.

简单来说,mergeSort(a,b)是这样一个函数,实现对于a到b之间的元素进行归并排序(a<b)
具体步骤是:
找到中点mid, ...

那这个程序是怎样得到(归并排序)a到mid得到排好序的序列A呢?我先弄透彻点
3楼2013-06-26 21:09:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

引用回帖:
3楼: Originally posted by 冰雨hust at 2013-06-26 21:09:08
那这个程序是怎样得到(归并排序)a到mid得到排好序的序列A呢?我先弄透彻点...

这就是递归的意义所在啊,从a到mid排序调用的是自身(从a到b,这时候b=mid而已)
参数a<b是递归出口,也就是说当仅有一个元素(a==b)时,递归就结束了,然后一层层返回去.

你用一个简单的3个元素的数组[1,2,3]画出函数调用层次就一下子明白了
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
4楼2013-06-27 00:14:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 冰雨hust 的主题更新
信息提示
请填处理意见