C语言怎么实现杨辉三角
发表于:2024-11-14 作者:千家信息网编辑
千家信息网最后更新 2024年11月14日,本篇内容介绍了"C语言怎么实现杨辉三角"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!杨辉三角--C语
千家信息网最后更新 2024年11月14日C语言怎么实现杨辉三角
本篇内容介绍了"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],所以我们按照这个方法将数据填入二维数组之后打印即可。
代码如下:
#includeint 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)。但是在填数据的时候不能对之前的数据覆盖,所以需要从后向前填。而填杨辉三角顺序对结果是没有影响的,所以可以实现。
代码如下:
#includeint 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语言怎么实现杨辉三角"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
杨辉三角
杨辉
三角
一行
数组
数据
方法
二维
语言
结果
j++
代码
内容
数字
更多
知识
规律
联系
输入
运行
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
中国互联网络安全中心主页
易班网络技术部面试
正在启动服务器卡死怎么办
个性化软件开发设计
百纳在线网络技术有限公司
软件开发业务信息资产识别
为什么上网要输入网络安全
周村家装erp软件开发
小黄车服务器
加强网络安全信息
英雄联盟帐号出现数据库
生鲜团购软件开发
菲菲网络技术部是国企吗
中央网络安全与信息安全
武邑县网络安全培训学校
数据库中求平均工资的语句
报税服务器返回为空
杭州市模具厂erp软件开发
服务器主机和运行端口一致吗
丛台区网络安全和信息化委员会
江苏电脑软件开发大概多少钱
网络安全值守工作内容
违反网络安全法会
软件开发mac电脑怎么样
生存曲线分析哪个数据库靠谱
bi软件开发面试题
g41服务器板开机跳线
服务器4t硬盘如何分区
服务器硬盘的选择
政务信息系统数据库国标