| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 539 人关注过本帖
标题:[求助] 递归
只看楼主 加入收藏
J华
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2007-7-2
收藏
 问题点数:0 回复次数:4 
[求助] 递归

下面是数字排列问题 别人写的个递归.....
public class Permutations {

private static void perm(char[] a, int n) {
if (n == 1) {
System.out.println(a);
return;
}
for (int i = 0; i < n; i++) {
swap(a, i, n-1);
perm(a, n-1);
swap(a, i, n-1);
}
}

// swap the characters at indices i and j
private static void swap(char[] a, int i, int j) {
char c;
c = a[i]; a[i] = a[j]; a[j] = c;
}

public static void main(String[] args) {
char[] chars = {'2','6','7','5'};
perm(chars, 4);
}
}
这种循环的递归,什么时候能够用? 设计思路是怎样的?

搜索更多相关主题的帖子: 递归 
2007-08-27 17:10
狂放不羁
Rank: 4
等 级:贵宾
威 望:12
帖 子:925
专家分:0
注 册:2007-1-24
收藏
得分:0 
这个问题和汉诺塔很像。具体思想是这样的:我们首先找出数组中的一个元素作为最后一个元素,对其他的前n-1个元素进行全排列,就好比有n个柱子,最后一个柱子就用来放数组中选出作为最后一个的元素的。首先把数组的第一个元素作为最后一个元素,然后对前n-1个元素进行排列,当排列完成后把最后一个柱子上的数字放到第一个上,因为下次最后一个柱子要用来放下一个数组元素。

[此贴子已经被作者于2007-8-27 19:46:31编辑过]


2007-08-27 19:45
J华
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2007-7-2
收藏
得分:0 
明白了一些 .
不过关键是遇到这种问题 能够马上写出递归来解决 尽管效率低,如果能想通 那么思路一定很清晰.

这个题 比如对a[3]进行全排列 我们首先找出数组中的一个元素作为第4位,对其他的前3个元素进行全排列.要对前3个数全排列,可以找出前3个元素中的一个数作为第3位,对前2个元素进行全排列..... 直到第1位的数确定 输出这个数.然后因为从n个数中找出一个数的遍历是for(int i=0;i<n;i++) 确定循环体.然后因为是用交换数组元素来实现的,所以每次确定1个数后要还原成原来的数组(空出第4位) 于是就有:


for (int i = 0; i < n; i++) {
swap(a, i, n-1);
perm(a, n-1);
swap(a, i, n-1);
}

这样吗?



2007-08-27 21:09
狂放不羁
Rank: 4
等 级:贵宾
威 望:12
帖 子:925
专家分:0
注 册:2007-1-24
收藏
得分:0 
恩,可以那么理解,不过不是空出第四位而是第四位和原先数组的第2位交换。。这样一次类推。。
2007-08-27 21:19
子阳
Rank: 1
等 级:新手上路
帖 子:71
专家分:0
注 册:2007-3-5
收藏
得分:0 
解释的不错!!!
学习了!!
2007-08-27 22:37
快速回复:[求助] 递归
数据加载中...
 
   



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

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