c语言--杨辉三角

本文介绍了如何使用C语言编程实现前10行的杨辉三角。关键在于对角线以下的数据输入,第一列始终为1,且每个元素是前一行两个相邻元素的和。通过双重循环结构初始化并计算数组元素。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

1、先使得输入的数据在对角线下方

可以看成它是由一个10行10列的的正方形,只取对角线以下的数据。我们输入数据的时候,也只需要对角线一下的数据,显示杨辉三角。

for(i=0;i<10;i++) //i表示行
for(j=0;j<=i;j++) //j表示列

这样循环输入的数据都是在对角线下方。

2、第一列始终为1

可以用

a[i][0]=1; //使得第一列始终为1

3、输入数据之间的规律

第一列的数据在上面已经出来了,下面就是怎么使得对角线下面的其他数据也符合杨辉三角的特性呢?
我们可以发现每一行从第二个数据开始都与前一行的前两列数据有关。
它的值等于它的前两行的前两列数据之和,即

a[i][j]=a[i-1][j-1]+a[i-1][j]

对角线上的元素在它上方的数据为0时,也满足该关系。

综上分析过程,我们就可以写出它的输入代码如下;

int a[10][10]={0}; //初始化数组内的元素全为0
for(i=0;i<10;i++)
{
a[i][0]=1;
for(j=1;j<i+1;j++)
{
a[i][j]=a[i-1][j-1]+a[i-1][j];
}
}

前10行杨辉三角完整代码如下

#include<stdio.h>
int main()
{
	int i,j;
	int a[10][10]={0};   //怎么定义这个数组?
	for(i=0;i<10;i++)
	{
		a[i][0]=1;
		for(j=1;j<i+1;j++)
		{
			a[i][j]=a[i-1][j-1]+a[i-1][j];
		}
	}
	for(i=0;i<10;i++)
	{
	 
		for(j=0;j<i+1;j++)
		{
			printf("%d\t",a[i][j]);
		}
		printf("\n");
	}
	
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值