第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

如何實(shí)現(xiàn)n個(gè)數(shù)字的全排列,包括可重復(fù)數(shù)字。

標(biāo)簽:
Java

/**

  1. 题目要求:随意输入n位正整数,(其中数字可重复例如112235),求出它的全排列情况(笔者用的是java实现,递归调用来实现具体算法)
    **/
    代码如下:
package com.gnnu2016;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Scanner;

public class randomAssortment {
    /**
     * 定义一个保存所有随机组合情况的动态数组
     */
    public static ArrayList<String>list=new ArrayList<String>();

    public static void main(String[] args) {
        long num = -1;
        Scanner input=new Scanner(System.in);
        /**
         * 判断数据的正确性
         */
        do{
            System.out.println("请输入一个正整数:");
            try{
                num=input.nextInt();
            }catch(Exception e){
                input.nextLine();
                System.out.println("输入错误,请重新输入!!");
            }
        }while(num<0);
        String string=Long.toString(num);
        String[]strings=string.split("");

        //调用函数,实现对list的填充所有的排列组合情况
        getRandom(strings,0,strings.length-1);

        //打印输出所有情况
        System.out.println("一共有"+list.size()+"种不同的排列,分别是:");
        for(int i=0;i<list.size();i++){
            System.out.print(list.get(i)+"  ");
            if((i+1)%10==0){
                System.out.println();
            }
        }
        System.out.println();
    }
    public static void getRandom(String[]strings,int start,int end){
        StringBuffer sBuffer=new StringBuffer();
        String string=null;
        /*
         * 一种排列情况已经出来了
         */
        if(start==end){
            for(int i=0;i<=end;i++){
                sBuffer.append(strings[i]);
            }
            string=sBuffer.toString();
            //判断该组合情况是否已经存在,如果不存在就添加该情况
            if(!list.contains(string)){
                list.add(string);
            }
        }else{
            for(int i=start;i<=end;i++){
                String temp=strings[start];
                strings[start]=strings[i];
                strings[i]=temp;

                //递归调用,直到start==end时表示递归结束
                getRandom(strings, start+1, end);

                temp=strings[start];
                strings[start]=strings[i];
                strings[i]=temp;
            }
        }
    }

}

如有不足之处,还望多多指点。。

點(diǎn)擊查看更多內(nèi)容
1人點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消