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

next_permutation函数(全排列)

时间:2020-05-05 23:41:25      阅读:83      评论:0      收藏:0      [点我收藏+]

标签:algorithm   end   ++   测试   clu   span   顺序   产生   div   

题目描述:有一个数n(1<n<10),写出1到n的全排列。

输入:第一行输入一个数n(0<n<10),表示有n组测试数据。后面的n行输入多组输入数据,每组输入数据都是一个整数x(0<x<10)

输出按特定顺序输出所有组合。
特定顺序:每一个组合中的值从小到大排列,组合之间按字典序排列。

输入:

2
2
3

输出:

12
21
123
132
213
231
312
321
#include<iostream>
#include<algorithm>
using namespace std;
int a[15];
int main()
{
    int n,x,i;
    cin>>n;
    ++n;
    while(--n)
    {
        cin>>x;
        for(i=0; i<x;++i)
            a[i]=i+1;
        for(i=0; i<x;++i)
            cout<<a[i];
        cout<<endl;
        while(next_permutation(a,a+x)==1)
        {
            for(i=0; i<x;i++)
                cout<<a[i];
            cout<<endl;
        }
    }
    return 0;
}

函数next_permutation()是按照字典序产生排列的,并且是从数组中当前的字典序开始依次增大直至到最大字典序。

next_permutation(),可以遍历全排列,要包含头文件<algorithm>

与之完全相反的函数还有prev_permutation

基本格式:

int a[];
while(next_permutation(a,a+n))
{
}

 

next_permutation函数(全排列)

标签:algorithm   end   ++   测试   clu   span   顺序   产生   div   

原文地址:https://www.cnblogs.com/hrlsm/p/12833501.html

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