美文网首页
递归处理数字全排列算法

递归处理数字全排列算法

作者: Moonsmile | 来源:发表于2017-02-18 16:36 被阅读0次

问题背景###

递归很常用,但确实不好理解,下边这段程序是用来进行数字全排列的
由于很多算法需要讲数字全排列后再来暴力求解问题,所以学会数字的全排列还是很有意义的
比如,讲1、2全排列后是1 2 和2 1

直接上java代码###

package permuta;

import java.util.Scanner;

public class Permutation {

    public static void permutation(int n,int A[],int cur){
        
        int i,j;
        //如果一旦验证满了n位数,就将这个数打印出来
        if(cur==n){
            for(i=0;i<n;i++)
            System.out.print(A[i]);
            System.out.println("\n");
            return ;
        }
        
        for(i=1;i<=n;i++){      
            int ok=1;
            for(j=0;j<cur;j++){
                if(A[j]==i)
                    ok=0;
            }
            //从左边位数开始放数,如果这个位数没有放过,这个位置就放i,放完之后的事就递归,交给别人去干了,就可以考虑下一个位数了
            if(ok==1){
                A[cur]=i;
                permutation(n, A, cur+1);//递归
            }
        }
        
    }
    
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int n,cur=0;
        int A[]={1,2,3,4,5,6,7,8,9};
        System.out.println("请输入你要全排列的个数");
        Scanner scanner=new Scanner(System.in);
        n=scanner.nextInt();
        permutation(n, A, cur);
    }

}

运行结果###

K(EHS80Q(I5Z0`G%SY7@~@3.png

![34W$%HUHI~HXF3L3C68]TEA.png](https://img.haomeiwen.com/i3403753/0b95f6d56af6b7ed.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

相关文章

  • 递归处理数字全排列算法

    问题背景### 递归很常用,但确实不好理解,下边这段程序是用来进行数字全排列的由于很多算法需要讲数字全排列后再来暴...

  • 全排列与字典序

    全排列 递归实现全排列; 首先来说递归算法实现全排列: 例如,对于{1,2,3,4}的例子进行全排列,其可以分解...

  • 46. Permutations

    算法 1: 递归数组 的全排列,等价于全排列与可能的取值组合得到。 算法 2: 计算一个排列 按字典升序排列的紧...

  • 全排列(递归算法)

    一. 全排列算法 首先:什么是全排列=》百度一下 从n个不同元素中任取m(m≤n)个元素,按照一定的顺序排列起来,...

  • 全排列(数字重复与不重复)问题的递归与非递归代码

    全排列给定一个数字列表,返回其所有可能的排列。 样例给出一个列表[1,2,3],其全排列为: 递归代码 非递归代码...

  • 全排列

    递归不支持字典序,只支持全排列 1. 不含重复元素的全排列 2. 含重复元素 非递归处理 支持处理重复元素(不包含...

  • 全排列的非递归算法

    import java.util.Arrays; //全排列的非递归算法 public class FullPer...

  • Leetcode.46.Permutations

    题目 给定一个没有重复数字的数字序列, 输出这写数字的全排列组合. 思路 这种全排列的问题最直接的思路就是递归. ...

  • P254-字符串的排列

    排列总结: 字符串的全排列和组合算法 1.递归实现 2.非递归实现 qsort函数、sort函数 (精心整理篇) ...

  • 算法复习之字符串(1)

    (1)字符串循环左移 | 字符串全排列(递归,非递归)《本节内容》(2)KMP算法| BF算法(3 字符串的最...

网友评论

      本文标题:递归处理数字全排列算法

      本文链接:https://www.haomeiwen.com/subject/pptdwttx.html