考察stl中next_permutation的运用
#include <bits/stdc++.h>
using namespace std;
int main() {
int n;
cin>>n;
vector<int>a(n);
vector<vector<int>>res;
for(int i=0;i<n;i++)
a[i]=i+1;
do {
res.push_back(a);
}while (next_permutation(a.begin(),a.end()));
for(int i=0;i<res.size();i++)
{
for(int j=0;j<n;j++)
{
cout<<res[i][j]<<(j==n-1?"":" ");
}
cout<<endl;
}
}
// 64 位输出请用 printf("%lld")

京公网安备 11010502036488号