| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3064 人关注过本帖
标题:关于回溯法怎么使用的问题
取消只看楼主 加入收藏
ai8343512
Rank: 2
等 级:论坛游民
帖 子:75
专家分:94
注 册:2011-8-7
结帖率:100%
收藏
已结贴  问题点数:40 回复次数:4 
关于回溯法怎么使用的问题
在另一个帖子里(ACM题目的那个)求全排列时要用到回溯法,但我看了好久都看不懂,求解释……int f3(int n, int m)
 int f3(int n, int m)
 {
     if(n < 1 || m < 1) return 0;
     if(n == 1 || m == 1) return 1;
     if(n < m) return f3(n, n);
     if(n == m) return f3(n, m - 1) + 1;
     return f3(n, m - 1) + f3(n - m, m);
 }
最好能举个简单的回溯法例子就好,谢谢了。
搜索更多相关主题的帖子: 最好 return 
2012-01-15 18:57
ai8343512
Rank: 2
等 级:论坛游民
帖 子:75
专家分:94
注 册:2011-8-7
收藏
得分:0 
回复 2楼 beyondyf
不好意思啊,我在网站上看到是说这道题用回溯法会很简单,然后又看到laoyang103的解答里面的这个程序段号简单,所以就认为回溯法了
我想了解回溯法到底怎么回事,我知道回溯法的原理就是一条一条的路去尝试,但不知道怎么能写出代码来,所以麻烦各位了。

思考不应该由他人来指导,会思考的人不需要你来提醒他去思考一个简单的问题。
2012-01-15 19:50
ai8343512
Rank: 2
等 级:论坛游民
帖 子:75
专家分:94
注 册:2011-8-7
收藏
得分:0 
回复 3楼 有容就大
3楼分析的真好,我想我差不多大概理解了
就当让自己更深一步理解吧,我也解说一下:
这段代码就是根据m的大小作为分段依据的,前面的n < m,n = m,都是通过递归转化为n > m的问题,然后n > m通过不断的递归,最终都可以化为f(n,1) + x*1(x的大小根据m的大小来确定)的问题,最终通过n=1 || m=1这个结束条件来结束程序,从而得到所有可能组合数的和。

[ 本帖最后由 ai8343512 于 2012-1-15 20:22 编辑 ]

思考不应该由他人来指导,会思考的人不需要你来提醒他去思考一个简单的问题。
2012-01-15 20:19
ai8343512
Rank: 2
等 级:论坛游民
帖 子:75
专家分:94
注 册:2011-8-7
收藏
得分:0 
回复 4楼 cuijingchun
最后一句其实是省略了if (n>m)的条件,因为经过前面四个if以后一定会转化为if (n>m)的情况,所以省略了if (n>m)这个条件不影响程序的进行

思考不应该由他人来指导,会思考的人不需要你来提醒他去思考一个简单的问题。
2012-01-15 20:27
ai8343512
Rank: 2
等 级:论坛游民
帖 子:75
专家分:94
注 册:2011-8-7
收藏
得分:0 
回复 11楼 有容就大
其它的方面?对于这段代码来说是不是还有其它可以延伸的地方?望指教。

思考不应该由他人来指导,会思考的人不需要你来提醒他去思考一个简单的问题。
2012-01-16 12:32
快速回复:关于回溯法怎么使用的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.074091 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved