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

下面是数字排列问题 别人写的个递归.....
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
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
快速回复:[求助] 递归
数据加载中...
 
   



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

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