二维数组实现杨辉三角

 参考链接: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;
}

结果如下

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

攻城狮晨哲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值