直接来吧:
#include<bits/stdc++.h>
using namespace std;
int n,a[15],u[15];
void dg(int dep)
{
if(dep>n)
{
for(int i=1;i<=n;i++)
cout<<setw(2)<<a[i];
cout<<endl;
}
else
{
for(int i=1;i<=n;i++)
{
if(u[i]==0)
{
a[dep]=i;
u[i]=1;
dg(dep+1);
u[i]=0;
}
}
}
}
int main()
{
cin>>n;
dg(1);
return 0;
}