【杨辉三角的两种解法——(超级详细)】

news2024/12/29 10:57:07

杨辉三角

1.杨辉三角简介🕵️

杨辉三角,是二项式系数在三角形中的一种几何排列。在欧洲,这个表叫做帕斯卡三角形。帕斯卡(1623----1662)是在1654年发现这一规律的,比杨辉要迟393年,比贾宪迟600年。杨辉三角是中国古代数学的杰出研究成果之一,它把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合。杨辉三角是中国数学史上的一个伟大成就。

杨辉三角

在知道了杨辉三角后,那我们怎么样来实现它呢?下面就来介绍c语言最常见的两种解法,数组法递归法

2解法

2.1数组法🧐

数组法是我们最容易想到的一种解法,当我们把杨辉三角适当变形一下,如下图

在这里插入图片描述

看到这个图时,二维数组的这种解法便油然而生。这时候我们不慌写代码,先把思路理清楚,下笔才能“如有神”。

思路实现 😊

在这里插入图片描述
观察杨辉三角我们得知,每一行的第一个数据必为1,每一列的最后一个也是必为1,我们又知道每一行数据的个数刚好等于行数,例如第五行有五个数据,第七行有七个数据。也就是说当每一行的列数等于1时,或者列数等于行数时,其数据必为1。

在这里插入图片描述
除去每一行的第一个和最后一个数,我们还观察知道,中间的每一个数都等于他的上一行的相同列的数加上一行的前一列的数。例如,第五行第三列的数6,等于第四行第二列的数3加上第四行第三列的数3。

由此,我们实现的大概思路就是,定义一个二维数组,遍历二维数组将相应地数据存放到二维数组中,最后打印二维数组。

代码实现💻

前提准备🤯

首先我们先定义一个二维数组arr1,Rows和Cols分别是行和列,我们用define来定义行和列。

#define Row 100
#define Col 100

我们还定义了一个num值,表示打印num行的杨辉三角,并且利用断言assert,num值小于Rows,否则报错程序结束。

    int num = 0;
	int arr[Row][Col] = { 0 };
	scanf("%d", &num);
	assert(num < Row);

写入✍️

二维数组定义好之后,我们接下来就是把相应的数据存放到二维数组中,这里我们利用两层for循环嵌套遍历二维数组写入数据。代码如下:

for (int i = 0; i < num; i++)
	{
		for (int j = 0; j <= i; j++)
		{
			if (j == 0 || j == i)
			{
				arr[i][j] = 1;
			}
			else
			{
				arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];
			}
		}
	}

这里我们需要注意的是,二维数组下标是从0开始,所以说我们把i和j的初值都赋值为0,并在if的判定条件里将 j == 1修改为j == 0。

输出✍️

输出打印杨辉三角我们还是利用两层for循环嵌套遍历打印输出,代码如下:

for (int i = 0; i < num; i++)
	{
		/*blank = num - i - 1;
		while (blank--)
		{
			printf(" ");
		}*/
		for (int j = 0; j <= i; j++)
		{
			printf("%-3d ", arr[i][j]);
		}
		printf("\n");
	}

这里我们需要注意的是里面多了个blank变量和一个while循环,这两个的作用是打印每行数据前的空格,使我们打印出来的杨辉三角接近等腰三角形,我们去掉的话打印出来的杨辉三角是直角三角形,实况图如下:

打印空格图:
在这里插入图片描述
去掉空格图:
在这里插入图片描述
还有一点就是%2d的2表示输出宽度,当大于输出宽度时,数据按原数据输出。当小于输出宽度2时,默认前补空格,有右对齐的效果。%-2d相反

源代码🐒

#include<stdio.h>
#include<assert.h>
#define Row 100
#define Col 100
int main()
{
	int num = 0;
	int blank = 0;
	int arr[Row][Col] = { 0 };
	scanf("%d", &num);
	assert(num < Row);
	for (int i = 0; i < num; i++)
	{
		for (int j = 0; j <= i; j++)
		{
			if (j == 0 || j == i)
			{
				arr[i][j] = 1;
			}
			else
			{
				arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];
			}
		}
	}
	for (int i = 0; i < num; i++)
	{
		/*blank = num - i - 1;
		while (blank--)
		{
			printf(" ");
		}*/
		for (int j = 0; j <= i; j++)
		{
			printf("%-3d ", arr[i][j]);
		}
		printf("\n");
	}

	return 0;
}

2.2递归法🧐

思路实现🕵️

我们知道杨辉三角除去每一行的第一个和最后一个数是1外,其他的每个数都是其上一行的同一列与前一列的和,而我们要用递归法的话就需要先确定递归的两大要点,出口和递归体。我们画图来分析递归的解法。

在这里插入图片描述

如上图,如果我们要打印第五行的6的话,就等于第四行的3加上3,而两个3又分别等于第三行的1加上2,2又等于1加上1。由此可知,递归的出口为当列数为第一列或者最后一列时,返回数据1。递归体为上一行的同一列加上前一列,如果不是第一列或者最后一列时就继续递归。如下图:

在这里插入图片描述
代码实现💻
主函数✍️

int main()
{
	int num = 0;
	int blank = 0;
	scanf("%d", &num);
	for (int i = 0; i < num; i++)
	{
		/*blank = num - i - 1;
		while (blank--)
		{
			printf(" ");
		}*/
		for (int j = 0; j <= i; j++)
		{
			printf("%2d ", Back_print(i, j));
		}
		printf("\n");
	}

这里的num和blank,while循环的功能与上文说的一样,就不提了。这里我们需要注意的是我们还是利用双层for循环嵌套,利用递归函数Back_Print的返回值直接打印。

递归函数✍️

int Back_print(int rows, int cols)
{
	if (cols == 0 || cols == rows)
	{
		return 1;
	}
		
	else
	{
		return Back_print(rows - 1, cols) + Back_print(rows - 1, cols - 1);
	}
		
}

这里我们需要注意的是,由于i与j的初始化还是从0开始,所以我们if的判定条件还是当Cols等于0或者Cols==Rows时,返回1。否则就递归传入上一行的同一列和前一列加起来。结果如图:

在这里插入图片描述
去掉banlk后
在这里插入图片描述

源代码🐒

//递归法
int Back_print(int rows, int cols)
{
	if (cols == 0 || cols == rows)
	{
		return 1;
	}
		
	else
	{
		return Back_print(rows - 1, cols) + Back_print(rows - 1, cols - 1);
	}
		
}
int main()
{
	int num = 0;
	int blank = 0;
	scanf("%d", &num);
	for (int i = 0; i < num; i++)
	{
		/*blank = num - i - 1;
		while (blank--)
		{
			printf(" ");
		}*/
		for (int j = 0; j <= i; j++)
		{
			printf("%2d ", Back_print(i, j));
		}
		printf("\n");
	}

	return 0;
}

杨辉三角的解法多种多样,这里介绍了比较常见的两种,相比较于递归法,数组法更加容易理解,递归法就相对来说比较抽象,对于递归法作者的建议是多多画图理解。递归法相比较于数组法,省去了二维数组的定义,不需要将数据存放直接打印,两种解法各有优点。本文鉴于作者水平有限,文中如有错误之处还望指正。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/868366.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python 11道字典练习题

前言 大家早好、午好、晚好吖 ❤ ~欢迎光临本文章 有字典 dic {“k1”: “v1”, “k2”: “v2”, “k3”: “v3”}&#xff0c;实现以下功能&#xff1a; 1、遍历字典 dic 中所有的key 参考答案&#xff1a; dic {k1: v1,k2:v2,k3:v3}for k in dic.keys():print(k)2、遍历…

【高阶数据结构】AVL树详解(图解+代码)

文章目录 前言1. AVL树的概念2. AVL树结构的定义3. 插入&#xff08;仅仅是插入过程&#xff09;4. 平衡因子的更新4.1 为什么要更新平衡因子&#xff1f;4.2 如何更新平衡因子&#xff1f;4.3 parent更新后&#xff0c;是否需要继续往上更新&#xff1f;4.4 平衡因子更新代码实…

【最全Kubernetes容器编排安装教程】

文章目录 环境准备主机间做信任使用ssh-copy-id命令实现免密登录的安装与配置1. 安装Git Bash软件2. 生成公钥3. SSH登录Linux服务器4. 公钥复制到Linux服务器5. SSH免密登录测试 安装ansible工具 升级内核版本使用elrepo源升级内核查看最新版内核安装最新的内核版本设置系统默…

C语言的链表的相关操作

本变博客源于自己想复习一下C语言&#xff0c;所以便自己动手复习了一下链表的相关操作。做个人记录使用。 main.c #include <stdio.h> #include "list.h"int main() {student *a;printf("hello world\n") ;printf("----初始化列表----------\…

阻塞队列的安全实现,定时器的安全实现(面试易考),超详细

一、&#x1f49b; 如何实现一个线程安全的阻塞队列 目前&#xff0c;当前代码是循环队列&#xff08;还没有进行改动&#xff09; head和tail的判空判断满两种方法: 1.浪费一个格子&#xff0c;当前走到head的前一个位置&#xff0c;就认为队列满的 2.单独搞一个变量&#xff…

【分布式系统】聊聊分布式事务中原子性

什么是分布式事务 在分布式系统中&#xff0c;一个是计算问题&#xff0c;也就是将多个任务&#xff0c;通过流控技术把不同的流量分发给不同的服务器进行处理。另一个就是存储&#xff0c;而只要设计的存储&#xff0c;就必然会引入从单体事务中衍生除的分布式事务问题。 事务…

css flex 上下结构布局

display: flex; flex-flow: column; justify-content: space-between;

战略方法论

父文章 人人都是战略家 2018年注册会计师公司战略与风险考点:swot分析_知识点_注册会计师 SWOT分析 一、基本原理 所谓SWOT分析&#xff0c;即基于内外部竞争环境和竞争条件下的态势分析&#xff0c;就是将与研究对象密切相关的各种主要内部优势、劣势和外部的机会和威胁等…

提高WordPress网站性能的24个技巧

你想加速你的WordPress网站吗&#xff1f;快速加载页面可改善用户体验、增加页面浏览量并帮助你优化WordPress SEO。在本文中&#xff0c;我们将分享最有用的WordPress网站性能速度优化技巧&#xff0c;以提高WordPress网站性能并加快你的网站速度。 与其他“X 优秀的 WordPres…

redis学习笔记(九)

文章目录 python对redis基本操作&#xff08;1&#xff09;连接redis&#xff08;2&#xff09;数据类型操作 python对redis基本操作 &#xff08;1&#xff09;连接redis # 方式1 import redisr redis.Redis(host127.0.0.1, port6379) r.set(foo, Bar) print(r.get(foo))# …

Xilinx DDR3学习总结——1、MIG核设置

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 Xilinx DDR3学习总结——1、MIG核设置 前言开发板 DDR信息MIG 设置前言 话说之前从来没有使用过DDR,工作中的项目都是流式处理的,没有一个大存储的需求,应该图像处理中DDR用的会比较多一些,但是一个这么…

SpringBoot05--axios网络请求

浏览器主动发送请求&#xff0c;服务器接收请求之后返回数据&#xff0c;通过vue进行数据绑定 请求成功&#xff0c;返回的数据会包装到response里面去&#xff08;返回成response的data属性&#xff09; 好的这边不太懂 在xxx.vue组件被创建和挂载&#xff08;渲染&#xff09…

在idea运行python文件

在idea运行python文件 如果在idea运行python文件而没有弹出run的选项&#xff0c;则点击File->Settings…->Plugins&#xff0c;在里面搜索python&#xff0c;如果没有显示则在Maketplace进行搜索&#xff0c; 接着Install&#xff0c;然后restart

C++ STL list

✅<1>主页&#xff1a;我的代码爱吃辣 &#x1f4c3;<2>知识讲解&#xff1a;C之 STL list介绍和模拟实现 ☂️<3>开发环境&#xff1a;Visual Studio 2022 &#x1f4ac;<4>前言&#xff1a;上次我们详细的介绍了vector&#xff0c;今天我们继续来介绍…

某大厂笔试(小*的车站的最近距离)

有一个环形的公路&#xff0c;上面共有n站&#xff0c;现在给定了顺时针第i站到第i1站之间的距离&#xff08;特殊的&#xff0c;也给出了第n站到第1站的距离&#xff09;&#xff0c;小*想着沿着公路第x站走到第y站&#xff0c;她想知道最短的距离是多少&#xff1f; 输入描述…

无涯教程-Perl - print函数

描述 此函数将LIST中的表达式的值打印到当前的默认输出文件句柄或FILEHANDLE指定的句柄中。 如果设置,则$\变量将添加到LIST的末尾。 如果LIST为空,则打印$_中的值。 print接受一个值列表,列表中的每个元素都将被解释为一个表达式。 语法 以下是此函数的简单语法- print…

谷歌发布多平台应用开发神器:背靠 AI 编程神器 Codey,支持 React、Vue 等框架,还能代码补全

一、概述 8 月 8 日&#xff0c;谷歌宣布推出 AI 代码编辑器 IDX&#xff0c;旨在提供基于浏览器的人工智能开发环境&#xff0c;用于构建全栈网络和多平台应用程序。谷歌在创建 IDX 时并没有构建新的 IDE&#xff08;集成开发环境&#xff09;&#xff0c;而是使用 VS Code 作…

网络安全(黑客)自学路线/笔记

想自学网络安全&#xff08;黑客技术&#xff09;首先你得了解什么是网络安全&#xff01;什么是黑客&#xff01; 网络安全可以基于攻击和防御视角来分类&#xff0c;我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”、“安全运营”、“安全…

代码随想录算法训练营第55天|动态规划part12|309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费、总结

代码随想录算法训练营第55天&#xff5c;动态规划part12&#xff5c;309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费、总结 309.最佳买卖股票时机含冷冻期 309.最佳买卖股票时机含冷冻期 思路&#xff1a; 区别在第i天持有股票的当天买入的情况&#xff0c…

【Kubernetes】神乎其技的K8s到底是什么,为什么被越来越多人使用

&#x1f680;欢迎来到本文&#x1f680; &#x1f349;个人简介&#xff1a;陈童学哦&#xff0c;目前学习C/C、算法、Python、Java等方向&#xff0c;一个正在慢慢前行的普通人。 &#x1f3c0;系列专栏&#xff1a;陈童学的日记 &#x1f4a1;其他专栏&#xff1a;CSTL&…