C语言——杨辉三角的实现并输出(递归)

1、杨辉三角,是二项式系数在三角形中的一种几何排列。如图,每个数等于它上方两数之和。第n行的数字有n项。

要实现杨辉三角,首先我们想到先实现每一项该如何得到,第二步将所得每一项排列成上图杨辉三角的形状将其输出。

1)我们通过以下递归来得到杨辉三角未经排版的每一项 :

int YangHui(int r, int c)//r代表行,c代表列
{
	return(c == 1 || c == r) ? 1 : YangHui(r - 1, c - 1) + YangHui(r - 1, c);
}

 未经排版的每一项 :

 2)开始将所得每一项排列成上图杨辉三角的形状将其输出。即在每一行的左边输出需要的空格数以呈现等腰三角的形状。

2、代码实现:

#include<stdio.h>
int YangHui(int r, int c)//实参i代表形参r,实参j代表形参c,即行与列
{
	return(c == 1 || c == r) ? 1 : YangHui(r - 1, c - 1) + YangHui(r - 1, c);
}
int main()
{
	int n;//杨辉三角的前n行
	int i, j;
	printf("需要输出几行杨辉三角(0~20):");
	scanf("%d", &n);
	for (i = 1; i <= n; i++)//控制每行
	{
		for (j = 0; j < n - i; j++)//每行的前n-i个位置输出空格
			printf("   ");//每次输出3个空格
		for (j = 1; j <= i; j++)//当前的第i行有j个元素,也就是:当前行是第i行,当前行一共有j列
			printf("%6d", YangHui(i, j));
		printf("\n");
	}
	return 0;
}

3、运行结果 :

  • 20
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值