首页 > 作文

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

更新时间:2023-04-04 09:05:39 阅读: 评论:0

目录
杨辉三角——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};//将第一行直接填好,为1printf("请输入要打印的行数:>");scanf("%d", &n);for (int i = 1; i < n; i++)//从第二2020元宵晚会行开始填{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语言杨辉三角内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文发布于:2023-04-04 09:05:38,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/b8665df1e766f4860964e4581f62dc9d.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:C语言杨辉三角两种实现方法.doc

本文 PDF 下载地址:C语言杨辉三角两种实现方法.pdf

标签:数组   方法   语言   数据
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图