这是偶写的非递归处理的程序,四楼的哥们不好意思,晚贴出来了。。。。
/* Note:Your choice is C IDE */
/*编写一个递归程序,用0和1填充一个n*2^n的数组,让这个数组表示所有N位二进制数。*/
#include "stdio.h"
#include "stdlib.h"
#include "math.h"
#define N 4 /*问题的长度*/
main()
{
int **fun(int);
int **p = fun(N);
int i,j;
for(i = 0;i<(int)pow(2.0,N);i++)
{
for(j = 0;j<N;j++)
printf("%5d",p[i][j]);
printf("\n");
}
}
/*非递回实现,返回一个二维整形数组*/
int **fun(int n)
{
int i,j,t;
/*i表示行数,j表示列数,t用来索引当前处理的行*/
int **p = malloc((int)pow(2.0,n) * sizeof(int*));
for(i=0;i<(int)pow(2.0,n);i++)
{
*(p+i) = malloc(n * sizeof(int));
for(j = 0;j < n;j++)
{
*(*(p+i)+j) = 1;/*初始化都为1,简化后面的赋值*/
}
}
/*按列处理,第j列有连续(int)pow(2.0,n-j-1)个0*/
for(j = 0;j < n;j++)
{
for(i = 0;i<(int)pow(2.0,n);i+= (int)pow(2.0,j+1))
{
for(t = i;t<i+(int)pow(2.0,j);t++)
{
*(*(p+t)+n-j-1) = 0;
}
}
}
return p;
}