C语言:输出一定行数的杨辉三角

杨辉三角简介

杨辉三角图解

在这里插入图片描述
在这里插入图片描述

杨辉三角特性

由图可知,杨辉三角的特性有:
(1)每一行第一个数以及最后一个数都为1
(2)每一行的列数递增,且每一行列数=行数
(3)每个数等于它上方两数之和
(4)每行数字左右对称,由1开始逐渐变大。

代码

#include <stdio.h>
#define N 20	//输出的杨辉三角的最大行数
int main(){

//定义存放杨辉三角值得二维数组和想要输出的杨辉三角的行数
	int a[N][N],n;	

//输入函数 输入想要的行数
	printf("请输入杨辉三角的行数:");
	scanf("%d",&n);

//初始化二维数组  由杨辉三角特性可知,每一行第一个数以及最后一个数都为1
	for(int i=0;i<n;i++){
		a[i][0]=a[i][i]=1;
		}

//
	for(int i=2;i<n;i++){	//因为第一行和第二行的值都为1,所以循环从第三行开始即可,此时i=2
		for(int j=1;j<i;j++){	//因为第一列的值都为1,所以列数的循环从第二列开始即可,此时j=1;因为每一行最后一列的值为1,无需改变值,所以列数的循环到倒数第二列结束,即j<i
			a[i][j]=a[i-1][j-1]+a[i-1][j];	//每个数等于上方两数字之和
		}
	}

//输出杨辉三角
	for(int i=0;i<n;i++){
		for(int j=0;j<=i;j++){
			printf("%d\t",a[i][j]);
		}
		printf("\n");
	}
	return 0;
} 

输出结果展示

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值