二维数组实现杨辉三角

 参考链接:http://c.biancheng.net/view/495.html

#include <stdio.h>

#define N 20

int main(int argc, const char *argv[])
{
	int a[N][N] = {{0}};             /*定义二维数组a[20][20]*/
	int i, j, k;
	int n = 0;

	while(n<=0 || n>20){             /*控制打印的行数不要太大,过大会造成显示不规范*/
		printf(">:");
		scanf("%d",&n);
	}

	for (i = 0; i < n; i++){
		a[i][0] = 1;                    /*两边的数令它为1,因为现在循环从1开始,就认为a[i][0]为第一个数*/
		for(j = 1; j <= i; j++)
			a[i][j] = a[i-1][j-1] + a[i-1][j];     /*除两边的数外都等于上两顶数之和*/ 
	}

	for (i = 0; i < n; i++){
		for(k = 0; k <= n-i; k++)
			printf("   ");              /*这一行主要是在输出数之前打上空格占位,让输出的数更美观*/
		for(j = 0; j <= i; j++)          /*j<=i的原因是不输出其它的数,只输出我们想要的数*/
			printf("%-6d",a[i][j]);
		putchar('\n');                   /*当一行输出完以后换行继续下一行的输出*/
	}

	return 0;
}

结果如下

猜你喜欢

转载自blog.csdn.net/Mr__Shen/article/details/84259039