|
加了一个参数,可以输出结果
#include <stdio.h>
#include <stdlib.h>
int n = 12;
int q(int i, int j, int k, int l,int s[20])
{
int ans = 0;
for(int a = ((1 << n) - 1) & ~(i | j | k), p = a & -a; a!=0; a ^= p, p = a & -a)
{s[l]=p;
ans += q(i | p, (j | p) * 2, (k | p) / 2, l + 1,s);
}
if(l == n)
{
for(int m=0;m<n;m++)
printf("%d ",s[m]);
printf("\n");
}
return l == n ? 1 : ans;
}
int main(int argc,char*argv[])
{
int t[2]={};
if (argc==2)n=atoi(argv[1]);
printf("%d\n", q(0, 0, 0, 0,t));
}
|
|