C语言杨辉三角两种实现方法

 更新时间:2021年12月31日 14:07:30   作者:Li_yizYa  
大家好,本篇文章主要讲的是C语言杨辉三角两种实现方法,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览

杨辉三角——C语言实现

杨辉三角:

在屏幕上打印杨辉三角。

1

1 1

1 2 1

1 3 3 1

……

根据上述例子可知:

1.每一行的第一个和第二个数为1;

2.其余的数为正上方和左边数字之和。

方法一:利用二维数组实现

解题思路:

根据杨辉三角的规律,我们可以定义一个二维数组来实现杨辉三角的打印,其中数字的规律为:

data[i][j] = data[i - 1][j] + data[i - 1][j - 1],所以我们按照这个方法将数据填入二维数组之后打印即可。

代码如下:

#include <stdio.h>
 
int main()
{
	int n;
	int data[30][30] = {1};//将第一行直接填好,为1
	printf("请输入要打印的行数:>");
	scanf("%d", &n);
	for (int i = 1; i < n; i++)//从第二行开始填
	{
		data[i][0] = 1;//将每一行第一列先初始化为1,防止越界
		for (int j = 1; j < i + 1; j++)
		{
			data[i][j] = data[i - 1][j] + data[i - 1][j - 1];
		}
	}
	for (int i = 0; i < n; i++)//打印二维数组
	{
		for (int j = 0; j < i + 1; j++)
		{
			printf("%d ", data[i][j]);
		}
		printf("\n");
	}
	return 0;
}

运行结果:

 

方法二(对方法一的改进):

由于我在填第n行的杨辉三角时,只跟第n-1行的杨辉三角产生联系,不会跟之前的有联系,所以没必要保存每一行的杨辉三角,利用一维数组,填一行打一行即可,这样能让空间复杂度从O(n^2)降低到O(n)。但是在填数据的时候不能对之前的数据覆盖,所以需要从后向前填。而填杨辉三角顺序对结果是没有影响的,所以可以实现。

代码如下:

#include <stdio.h>
 
int main()
{
	int n;
	int data[30] = { 1 };
	printf("请输入要打印的行数:>");
	scanf("%d", &n);
	printf("1\n");//直接打印第一行
	for (int i = 1; i < n; i++)//从第二行开始
	{
		for (int j = i; j > 0; j--)//从后往前填,避免上一行的数据在使用前就被覆盖
		{
			data[j] += data[j - 1];
		}
		for (int j = 0; j <= i; j++)
		{
			printf("%d ", data[j]);
		}
		printf("\n");
	}
	return 0;
}

运行结果: 

 总结

到此这篇关于C语言杨辉三角两种实现方法的文章就介绍到这了,更多相关C语言杨辉三角内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++的多态和虚函数你真的了解吗

    C++的多态和虚函数你真的了解吗

    这篇文章主要为大家详细介绍了C++的多态和虚函数,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • C语言解数独程序的源码

    C语言解数独程序的源码

    这篇文章主要为大家详细介绍了C语言解数独程序的源码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • C++11中的可变参数模板/lambda表达式

    C++11中的可变参数模板/lambda表达式

    C++11的新特性可变参数模板能够让我们创建可以接受可变参数的函数模板和类模板,相比C++98和C++03,类模板和函数模板中只能含固定数量的模板参数,可变参数模板无疑是一个巨大的改进,这篇文章主要介绍了C++11中的可变参数模板/lambda表达式,需要的朋友可以参考下
    2023-03-03
  • C语言函数传递数组和传递地址的区别你知道吗

    C语言函数传递数组和传递地址的区别你知道吗

    这篇文章主要介绍了C语言中数组作为函数的参数以及返回值的使用简单入门,这里以一维数组作为基本条件进行例子讲解,需要的朋友可以参考下
    2021-09-09
  • Qt6.0 qproperty-*不生效原因解决分析

    Qt6.0 qproperty-*不生效原因解决分析

    这篇文章主要为大家介绍了Qt6.0 qproperty-*不生效原因解决分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • VScode配置C语言环境完整版(亲测可用)

    VScode配置C语言环境完整版(亲测可用)

    这篇文章主要介绍了VScode配置C语言环境完整版,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • VC外部符号错误_main,_WinMain@16,__beginthreadex解决方法

    VC外部符号错误_main,_WinMain@16,__beginthreadex解决方法

    这篇文章主要介绍了VC外部符号错误_main,_WinMain@16,__beginthreadex解决方法,实例分析了比较典型的错误及对应的解决方法,需要的朋友可以参考下
    2015-05-05
  • C程序中唯一序列号的生成实例详解

    C程序中唯一序列号的生成实例详解

    这篇文章主要介绍了C程序中唯一序列号的生成实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • epoll封装reactor原理剖析示例详解

    epoll封装reactor原理剖析示例详解

    这篇文章主要为大家介绍了epoll封装reactor原理剖析示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • C++11/14如何使用typedef和using定义类型别名和别名模版

    C++11/14如何使用typedef和using定义类型别名和别名模版

    这篇文章主要介绍了C++11/14如何使用typedef和using定义类型别名和别名模版
    2023-04-04

最新评论