A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© zhaoqiqi 初级黑马   /  2014-4-5 19:19  /  1400 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

已知如下一个递归程序,该程序的目的是输出给定字符的所有排列,请分析该程序的递归过程,然后将其用人工栈进行模拟,也就是将该递归程序转换成非递归程序:
public static void main(String[] args )
{
char myString[]={'a','b','c','d'};
permutation(myString,0,3);
}

public static void permutation(char[] list,int low,int high){
if(low==high){
  System.out.println(list);
  return ;
}
else{
  for(int i=low;i<=high;i++)
  {
   char temp=list[low];
   list[low]=list[i];
   list[i]=temp;
   permutation(list,low+1,high);
   temp=list[low];
   list[low]=list[i];
   list[i]=temp;
  }
}
}

评分

参与人数 1技术分 +1 收起 理由
朱神必 + 1

查看全部评分

3 个回复

倒序浏览
非递归方法通常就是对递归方法的栈模拟。比如输出n个字符,可以将任务分成n个子任务。任务0:将0位和0位字符交换,之后产生一个新的子任务,就是1到n-1位字符的全排列;任务1,将0位和1位字符交换,之后产生一个新的子任务,就是2到n-1位字符的全排列,以此类推,直到第n-2个子任务,是将n-1位的一个元素全排列。每个子任务完成后要将两个元素再交换回来。可以设置一个任务栈,专门存放每个任务的状态,其中有三个成员,i:当前位,j:欲交换位,n:第几次出栈。每个任务会出两次栈,第一次处理该任务,判断是否输出,是否产生新的子任务。第二次交换回来位置。
  1. import java.util.*;

  2. public class StackTest {

  3.         /**
  4.          * @param args
  5.          */
  6.         public static void main(String[] args) {
  7.                 List<Character> list = new ArrayList<Character>();
  8.                 list.add('a');
  9.                 list.add('b');
  10.                 list.add('c');
  11.                 list.add('d');
  12.                 permutation(list);

  13.         }

  14.         public static void permutation(List<Character> list) {
  15.                 Stack<State> stack = new Stack<State>();
  16.                 int l = list.size();
  17.                 State temp = new State(0, 0, 0);
  18.                 for (int i = 0; i < l; i++)
  19.                 // 初始化栈,l个任务
  20.                         stack.push(new State(0, i, 0));
  21.                         // 栈空则结束
  22.                 while (!stack.isEmpty()) {
  23.                         // 弹出一个当前任务
  24.                         temp = stack.pop();
  25.                         // 如果已排到最后队尾,则打印当前数组
  26.                         if (temp.i == l - 1)
  27.                                 System.out.println(list);
  28.                         // 否则分解子任务
  29.                         else {
  30.                         //交换队列元素
  31.                                 Collections.swap(list, temp.i, temp.j);
  32.                                 if (temp.n == 0) {
  33.                                         temp.n += 1;
  34.                                         stack.push(temp);
  35.                                         int k=temp.i+1;
  36.                                         for (int x =k; x < l; ++x)
  37.                                                 stack.push(new State(k, x, 0));
  38.                                 }
  39.                         }

  40.                 }
  41.         }
  42. }

  43. class State {
  44.         public int i;
  45.         public int j;
  46.         public int n;

  47.         public State(int i, int j, int n) {
  48.                 this.i = i;
  49.                 this.j = j;
  50.                 this.n = n;
  51.         }
  52. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
zzkang0206 + 1

查看全部评分

回复 使用道具 举报
本帖最后由 zhaoqiqi 于 2014-4-10 12:45 编辑

已经解决了,谢谢你的回答
回复 使用道具 举报
hyace 发表于 2014-4-6 12:25
非递归方法通常就是对递归方法的栈模拟。比如输出n个字符,可以将任务分成n个子任务。任务0:将0位和0位字 ...

已经解决了,谢谢你的回答
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马