输出全排列(C++版)

目录

                                           输出全排列                                          

一、问题描述

二、运行环境说明

三、代码段

四、效果展示 


                                           输出全排列                                          

备注:大二(上)数据结构课程设计A题

一、问题描述

请编写程序输出前n个正整数的全排列(n<10),

并通过9个测试用例(即n从1到9)观察n逐步增大时程序的运行时间

输入格式:

输入给出正整数n(<10)

输出格式:

输出1到n的全排列。每种排列占一行,数字间无空格。

排列的输出顺序为字典序,即序列a​1​​,a​2​​,⋯,an​​排在序列b​1​​,b​2​​,⋯,bn​​之前,

如果存在k使得a​1​​=b​1​​,⋯,ak​​=bk​​ 并且 ak+1​​<bk+1​​

输入样例:

3

输出样例:

123

132

213

231

312

321

二、运行环境说明

输出全排列(C++版)_第1张图片

三、代码段

#include 
#include 
using namespace std;

const int N = 20;

int n;
bool st[N];
int path[N];
clock_t startTime,endTime;

void dfs(int u)
{
    if(u == n)
      {
          for (int i = 0; i < n; i++)
            printf("%d",path[i]);
          puts("");
          return;
      }
      
    for (int i = 1; i <= n; i ++)
      {
          if(!st[i])
            {
                path[u] = i;
                st[i] = true;
                dfs(u+1);
                st[i] = false;
            }
      }
}

int main()
{
    cin>>n;
    
    startTime = clock();
    dfs(0);
    endTime = clock();
    cout<<"n等于"<

四、效果展示 

输出全排列(C++版)_第2张图片

输出全排列(C++版)_第3张图片

输出全排列(C++版)_第4张图片

输出全排列(C++版)_第5张图片

你可能感兴趣的:(课程设计与实验,c++,算法,课程设计)