C语言用一维数组打印杨辉三角(原:无意中想到)

本贴地址

 //求前10行的数
1 int a[11] = { 1 }; 2 a[0] = 1, a[1] = 1; 3 int i, j,m; 4 for (i = 2; i <= 11; i++) //2-11 输出10行 5 { 6 for (j = i - 1; j > 1; j--) //关键在这句,倒着求 7 { 8 a[j] = a[j] + a[j - 1]; 9 printf("%5d", a[j]); 10 } 11 printf("%5d\n",a[0]); 12 }

本来是a[j]=a[j]+a[j-1]

结果发现计算a[j+1]时,不行了,就想到了倒着来求,正好杨辉三角也是左右对称的,结果输出的意思是左右数颠倒的,然而左右对称,所以可行

//关键在这一句,倒着求,利用杨辉三角的对称性
posted @ 2015-11-19 16:14  yuzhang314  阅读(5355)  评论(0编辑  收藏  举报