#include<stdio.h>
#include<math.h>
void gray(int j,int n,int k,int a[100][100])
{
if((n)==j)
return ;
else
{
for(int i=0;i<k/2;i++)
{
a[i][j]=0;
a[k-i-1][j]=1;
}
gray(j+1,n,k/2,a);
for(int i=k;i<2*k;i++)
for(j;j<n;j++)
a[i][j]=a[2*k-i-1][j];
}
}
int main()
{
int n,k,x=0;
scanf("%d",&n);
k=pow(2,n);
int a[100][100];
int j=0;
gray(j,n,k,a);
for(int i=0;i<k;i++)
{
for(int j=0;j<n;j++)
printf("%d",a[i][j]);
printf("\n");
}
return 0;
}
不知道你这个问题是否已经解决, 如果还没有解决的话:
如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^