IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 【C语言】杨辉三角常用且简单的两种解法(超详细解说) -> 正文阅读

[C++知识库]【C语言】杨辉三角常用且简单的两种解法(超详细解说)

学习就是重复重复再重复!!!

??????????????

目录

?💙杨辉三角简介

??解法1:数组法

💛思路实现

💓代码实现

💖前提准备

?💜写入

💚输出

💗源代码

?💕解法二:递归法

💘思路实现

?🌟代码实现

???主函数

💥递归函数

???源代码

🐇总结


?💙杨辉三角简介

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

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

??解法1:数组法

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

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

💛思路实现

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

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

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

💓代码实现

💖前提准备

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

#define Rows 100
#define Cols 100

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

int arr1[Rows][Cols] = { 0 };
int num = 0;
scanf("%d", &num);
assert(num < Rows);

?💜写入

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

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

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

💚输出

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

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

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

打印空格图:

?去掉空格图:

还有一点就是%2d的2表示输出宽度,当大于输出宽度时,数据按原数据输出。当小于输出宽度2时,默认前补空格,有右对齐的效果。%-2d相反。

💗源代码

#include <stdio.h>
#include <assert.h>

#define Rows 100
#define Cols 100

int main()
{
	int arr1[Rows][Cols] = { 0 };
	int num = 0;
	scanf("%d", &num);
	assert(num < Rows);
	for (int i = 0; i < num; i++)
	{
		for (int j = 0; j <= i; j++)
		{
			if (j == 0 || j == i)
			{
				arr1[i][j] = 1;
			}
			else
			{
				arr1[i][j] = arr1[i - 1][j - 1] + arr1[i - 1][j];
			}
		}
	}
	for (int i = 0; i < num; i++)
	{
		int blank = num - i - 1;
		while (blank--)
		{
			printf(" ");
		}
		for (int j = 0; j <= i; j++)
		{
			printf("%2d ", arr1[i][j]);
		}
		printf("\n");
	}
	return 0;
}

?💕解法二:递归法

💘思路实现

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

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

?🌟代码实现

???主函数

int main()
{
	//杨辉三角的递归打印
	int num = 0;
	scanf("%d", &num);
	int blank = 0;
	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;
}

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

💥递归函数

int Back_Print(int Rows, int Cols)
{
	if (Cols == 0 || Rows == Cols)
	{
		return 1;
	}
	else
	{
		return Back_Print(Rows - 1, Cols) + Back_Print(Rows - 1, Cols - 1);
	}
}

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

去掉blank后:

???源代码

#include <stdio.h>

int Back_Print(int Rows, int Cols)
{
	if (Cols == 0 || Rows == Cols)
	{
		return 1;
	}
	else
	{
		return Back_Print(Rows - 1, Cols) + Back_Print(Rows - 1, Cols - 1);
	}
}

int main()
{
	//杨辉三角的递归打印
	int num = 0;
	scanf("%d", &num);
	int blank = 0;
	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;
}

🐇总结

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

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-15 01:47:57  更:2022-09-15 01:49:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 12:59:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码