24小时热门版块排行榜    

查看: 540  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 312求调剂 +3 上岸吧ZJY 2026-03-22 5/250 2026-03-25 14:50 by 雾散后相遇lc
[考研] 329求调剂 +3 钮恩雪 2026-03-25 3/150 2026-03-25 14:43 by 糖加冰
[考研] 各位老师您好:本人初试372分 +5 jj涌77 2026-03-25 6/300 2026-03-25 14:15 by mapenggao
[考研] 求调剂 +3 李李不服输 2026-03-25 3/150 2026-03-25 13:03 by cmz0325
[考研] 359求调剂 +3 王了个楠 2026-03-25 3/150 2026-03-25 12:50 by Dyhoer
[考研] 081700 调剂 267分 +10 迷人的哈哈 2026-03-23 10/500 2026-03-25 12:12 by userper
[考研] 材料调剂 +3 iwinso 2026-03-23 3/150 2026-03-25 11:29 by greychen00
[考研] 318求调剂 +3 plum李子 2026-03-23 3/150 2026-03-25 09:42 by 雾散后相遇lc
[考研] 求调剂,一志愿:南京航空航天大学大学 ,080500材料科学与工程学硕,总分289分 +6 @taotao 2026-03-19 6/300 2026-03-25 08:37 by 木托莫露露
[考研] 调剂 +4 13853210211 2026-03-24 4/200 2026-03-24 19:44 by ms629
[考研] 0854 考研调剂 招生了!AI 方向 +5 pk3725069 2026-03-19 17/850 2026-03-24 17:30 by zhouxuan..
[考研] 环境学硕288求调剂 +8 皮皮皮123456 2026-03-22 8/400 2026-03-23 23:47 by 热情沙漠
[考研] 335分 | 材料与化工专硕 | GPA 4.07 | 有科研经历 +4 cccchenso 2026-03-23 4/200 2026-03-23 23:00 by 徐ckkk
[考研] 328求调剂 +4 LHHL66 2026-03-23 4/200 2026-03-23 14:55 by lbsjt
[考研] 070300,一志愿北航320求调剂 +3 Jerry0216 2026-03-22 5/250 2026-03-23 09:16 by 。。堂堂
[考研] 317求调剂 +12 申子申申 2026-03-19 18/900 2026-03-22 22:23 by luoyongfeng
[考研] 求调剂一志愿海大,0703化学学硕304分,有大创项目,四级已过 +6 幸运哩哩 2026-03-22 10/500 2026-03-22 20:10 by edmund7
[考研] 考研调剂 +4 来好运来来来 2026-03-21 4/200 2026-03-22 12:15 by 星空星月
[考研] 0703化学297求调剂 +3 Daisy☆ 2026-03-20 3/150 2026-03-21 17:45 by ColorlessPI
[考研] 288求调剂 +16 于海海海海 2026-03-19 16/800 2026-03-20 22:28 by JourneyLucky
信息提示
请填处理意见