博客
关于我
杨辉三角(详解)
阅读量:763 次
发布时间:2019-03-23

本文共 1456 字,大约阅读时间需要 4 分钟。

杨辉三角

分析

杨辉三角是一种以数形成的几何形状,因其结构独特而备受关注。以下是其主要特点:

  • 结构特征

    • 第一列(即左上角到右下角的对角线)及所有对角线上的元素均为1。
    • 除第一列和对角线外,其它元素的生成规律依赖于前一个元素的位置:每个元素等于其直接上方元素与直接左方元素的和。
  • 递归规律可视化

    • 通过对比原始杨辉三角与生成后的图像,可以清晰看到每个非边沿元素的生成方式。
    • 例如,第5行第4列的数值 = 第4行第3列的数值 + 第4行第4列的数值。
  • [图片描述已移除]

    代码实现

    方法一

    #define _CRT_SECURE_NO_WARNINGS#include 
    int main() { int i, j, n; int a[100][100] = {0}; while (n < 1 || n > 100) { printf("请输入要打印的杨辉三角行数:"); scanf("%d", &n); } for (i = 0; i < n; i++) { a[i][0] = 1; } for (i = 1; i < n; i++) { for (j = 1; j <= i; j++) { a[i][j] = a[i - 1][j - 1] + a[i - 1][j]; } } for (i = 0; i < n; i++) { for (j = 0; j <= i; j++) { printf("%5d", a[i][j]); } printf("\n"); } return 0;}

    方法二

    #define _CRT_SECURE_NO_WARNINGS#include 
    int main() { int i, j, n; int a[100][100] = {1}; while (n < 1 || n > 100) { printf("请输入要打印的杨辉三角行数:"); scanf("%d", &n); } for (i = 1; i < n; i++) { a[i][0] = 1; for (j = 1; j <= i; j++) { a[i][j] = a[i - 1][j - 1] + a[i - 1][j]; } } for (i = 0; i < n; i++) { for (j = 0; j <= i; j++) { printf("%5d", a[i][j]); } printf("\n"); } return 0;}

    解释

  • 初始化

    • 方法一中,二维数组a初始化为0。
    • 方法二中,二维数组a的所有元素初始化为1。
  • 输入处理

    • 两种方法均首先通过while循环确保输入数值合理。
  • 杨辉三角构建

    • outer for循环决定行数。
    • inner for循环决定列数,依次计算每个元素的值。
  • 输出

    • 通过循环逐行打印杨辉三角,每元素按格式输出。
  • 以上两种方法均有效地模拟了杨辉三角的生成过程,适合用于教学和验证参考。

    转载地址:http://faqzk.baihongyu.com/

    你可能感兴趣的文章
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql 优化器 key_mysql – 选择*和查询优化器
    查看>>
    MySQL 优化:Explain 执行计划详解
    查看>>
    mysql 修改默认字符集为utf8
    查看>>
    Mysql 共享锁
    查看>>
    mysql 写入慢优化
    查看>>
    mysql 创建表,不能包含关键字values 以及 表id自增问题
    查看>>
    mysql 判断表字段是否存在,然后修改
    查看>>
    MySQL 多表联合查询:UNION 和 JOIN 分析
    查看>>
    MySQL 大数据量快速插入方法和语句优化
    查看>>
    mysql 如何给SQL添加索引
    查看>>
    mysql 字段区分大小写
    查看>>
    mysql 字段类型类型
    查看>>
    MySQL 存储引擎
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    mysql 自增id和UUID做主键性能分析,及最优方案
    查看>>
    Mysql 自定义函数
    查看>>
    mysql 行转列 列转行
    查看>>
    Mysql 表分区
    查看>>
    mysql 表的操作
    查看>>