码迷,mamicode.com
首页 > 其他好文 > 详细

【回溯】数字排列问题

时间:2016-08-07 12:05:54      阅读:106      评论:0      收藏:0      [点我收藏+]

标签:

问题 S: 【回溯】数字排列问题

时间限制: 1 Sec  内存限制: 128 MB
提交: 11  解决: 9
[提交][状态][讨论版]

题目描述

列出所有从数字1到数字n的连续自然数的排列,要求所产生的任一数字序列中不允许出现重复的数字。

输入

n(1≤n≤9)

输出

由1~n组成的所有不重复的数字序列,每行一个序列。

样例输入

3

样例输出

    1    2    3
    1    3    2
    2    1    3
    2    3    1
    3    1    2
    3    2    1

解题思路:
  跟n皇后解法很类似,写递归函数,找好退出条件。

代码:
#include <iostream>
#include <cstdio>

using namespace std;

int n;
int a[10]={0};
int yn[10]={0};

void backtrack(int location){
    if(location==n+1){
        for(int i=1;i<=n;i++){
            printf("    %d",a[i]);
        }
        printf("\n");
    }else{
        for(int i=1;i<=n;i++){
            if(!yn[i]){
                a[location]=i;
                yn[i]=1;
                backtrack(location+1);
                yn[i]=0;
            }
        }
    }
}

int main()
{
    scanf("%d",&n);
    backtrack(1);
    return 0;
}

 

【回溯】数字排列问题

标签:

原文地址:http://www.cnblogs.com/TWS-YIFEI/p/5745656.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!