前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >递归处理数字全排列算法

递归处理数字全排列算法

作者头像
张俊怡
发布2018-04-24 13:58:44
9580
发布2018-04-24 13:58:44
举报

问题背景###

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

直接上java代码###

代码语言:javascript
复制
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);
    }

}

运行结果###

(http://upload-images.jianshu.io/upload_images/3403753-0b95f6d56af6b7ed.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017.02.18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题背景###
  • 直接上java代码###
  • 运行结果###
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档