尼采般地抒情

公告栏

此网站主题为本人手写主题,主题还在开发中……


作者:尼采般地抒情
本站主页面和blog页面暂时一样,目的是为了百度收录,百度收录之后,会将主页换回引导页~

站点信息

文章数目:195
已运行时间:
目录
  1. 问题描述
  2. 问题思路
  3. 代码思路
  4. 代码实现

尼采般地抒情

尼采般地抒情

公告栏

此网站主题为本人手写主题,主题还在开发中……


作者:尼采般地抒情
本站主页面和blog页面暂时一样,目的是为了百度收录,百度收录之后,会将主页换回引导页~

站点信息

文章数目:195
已运行时间:

问题描述

给定 n 个有序元素的集合,列出其可能出现的排列。

问题思路

代码思路

  • 利用动态数组数据结构

代码实现

package com.wztlink1013.al._递归法_;
import java.util.ArrayList;

/**
 * 全排列问题
 * */

public class Permuting {
    static ArrayList<Integer> x  = new ArrayList<Integer>();
    static int N;
    static int cnt = 0;
    static int t;

    public static void main(String args[]) {
        int n = 10;
        Times.test("当n = " + n + "时候的耗费时间", new Times.Task() {
            public void execute() {
                PermutingCaller(n);
            }
        });
    }
    private static void PermutingCaller(int n) {
        N = n;
        for (int i = 0; i < n; ++i)
            x.add(i + 1);
        Permuting(0);
    }
    private static void Permuting(int i) {
        if (i < N - 1) {
            for (int j = i; j < N; j++) {
                t = x.get(i);
                x.set(i, x.get(j));
                x.set(j, t);
                Permuting(i + 1);
                t = x.get(i);
                x.set(i, x.get(j));
                x.set(j, t);
            }
        }
        else
            OutputOnePermutation();
    }
    private static void OutputOnePermutation()
    {
        System.out.print(++cnt + " : ");
        for (int x : x)
            System.out.print(x + " ");
        System.out.println();
    }
}

n:10

n

博客内容遵循: 署名-非商业性使用-禁止演绎 4.0 国际(CC BY-NC-ND 4.0)

本文永久链接: https://www.wztlink1013.com/blog/kgaymi/

编辑: 部署: 订阅:

评论区

Twikoo 转换 utterances

最新评论

Loading...