当前位置: 首页 > news >正文

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

一.杨辉三角的数学原理

  • 杨辉三角的定义:二项式系数在三角形中的几何排列

二.基础二维数组法


#include <stdio.h>
#define N 10void printPascalTriangle(int n) {int triangle[N][N];// 初始化第一列和对角线为1for (int i = 0; i < n; i++) {triangle[i][0] = 1;triangle[i][i] = 1;}// 计算中间元素for (int i = 2; i < n; i++) {for (int j = 1; j < i; j++) {triangle[i][j] = triangle[i-1][j-1] + triangle[i-1][j];}}// 打印三角形for (int i = 0; i < n; i++) {// 打印前导空格for (int k = 0; k < n - i - 1; k++) {printf(" ");}for (int j = 0; j <= i; j++) {printf("%d ", triangle[i][j]);}printf("\n");}
}int main() {printPascalTriangle(10);return 0;
}​
  • 使用二维数组存储每个元素

  • 第一列和对角线元素都为1

  • 其他元素等于上一行同列和前一列元素之和

  • 简单直观,但空间复杂度为O(n²)

三.优化空间的一维数组法 

#include <stdio.h>
#define N 10void printPascalTriangle(int n) {int row[N];for (int i = 0; i < n; i++) {// 从后往前计算避免覆盖row[i] = 1;for (int j = i - 1; j > 0; j--) {row[j] = row[j] + row[j-1];}// 打印前导空格for (int k = 0; k < n - i - 1; k++) {printf(" ");}// 打印当前行for (int j = 0; j <= i; j++) {printf("%d ", row[j]);}printf("\n");}
}int main() {printPascalTriangle(10);return 0;
}
  • 只使用一维数组,空间复杂度降为O(n)

  • 从后往前计算避免覆盖前一次的结果

  • 更高效的内存使用,但逻辑稍复杂

四.递归实现

#include <stdio.h>int pascalValue(int row, int col) {if (col == 0 || col == row) {return 1;}return pascalValue(row - 1, col - 1) + pascalValue(row - 1, col);
}void printPascalTriangle(int n) {for (int i = 0; i < n; i++) {// 打印前导空格for (int k = 0; k < n - i - 1; k++) {printf(" ");}for (int j = 0; j <= i; j++) {printf("%d ", pascalValue(i, j));}printf("\n");}
}int main() {printPascalTriangle(10);return 0;
}
  • 使用递归计算每个位置的值

  • 代码简洁,符合数学定义

  • 效率较低,有大量重复计算

  • 时间复杂度为O(2ⁿ)

五.组合数公式法

#include <stdio.h>int factorial(int n) {if (n == 0) return 1;return n * factorial(n - 1);
}int combination(int n, int k) {return factorial(n) / (factorial(k) * factorial(n - k));
}void printPascalTriangle(int n) {for (int i = 0; i < n; i++) {// 打印前导空格for (int k = 0; k < n - i - 1; k++) {printf(" ");}for (int j = 0; j <= i; j++) {printf("%d ", combination(i, j));}printf("\n");}
}int main() {printPascalTriangle(10);return 0;
}
  • 利用组合数公式C(n,k) = n!/(k!(n-k)!)

  • 数学意义明确

  • 计算阶乘容易溢出,效率不高

  • 适合理论理解,实际应用有限

 六.动态规划优化

#include <stdio.h>
#define N 10void printPascalTriangle(int n) {int triangle[N][N];for (int i = 0; i < n; i++) {// 打印前导空格for (int k = 0; k < n - i - 1; k++) {printf(" ");}for (int j = 0; j <= i; j++) {// 第一列和对角线为1if (j == 0 || j == i) {triangle[i][j] = 1;} else {triangle[i][j] = triangle[i-1][j-1] + triangle[i-1][j];}printf("%d ", triangle[i][j]);}printf("\n");}
}int main() {printPascalTriangle(10);return 0;
}
  • 结合了方法一和方法二的优点

  • 边计算边打印,减少内存访问

  • 代码结构更紧凑

  • 仍然使用二维数组,但计算和输出合并

七.使用指针的方法 

#include <stdio.h>
#include <stdlib.h>void printPascalTriangle(int n) {int **triangle = (int **)malloc(n * sizeof(int *));for (int i = 0; i < n; i++) {triangle[i] = (int *)malloc((i + 1) * sizeof(int));triangle[i][0] = 1;triangle[i][i] = 1;for (int j = 1; j < i; j++) {triangle[i][j] = triangle[i-1][j-1] + triangle[i-1][j];}// 打印前导空格for (int k = 0; k < n - i - 1; k++) {printf(" ");}for (int j = 0; j <= i; j++) {printf("%d ", triangle[i][j]);}printf("\n");}// 释放内存for (int i = 0; i < n; i++) {free(triangle[i]);}free(triangle);
}int main() {printPascalTriangle(10);return 0;
}
  • 使用指针动态分配内存

  • 可以处理更大的n值(受内存限制)

  • 需要手动管理内存

  • 更接近实际工程应用

相关文章:

  • 二分查找----1.搜索插入位置
  • 基于Spring+MyBatis+MySQL实现的监考安排与查询系统设计与实现(附源码+数据库)推荐!
  • OCCT基础类库介绍:Modeling Algorithm - Sewing
  • 使用docker-compose安装kafka
  • FramePack 安装指南(中文)
  • Java八股文——数据结构「排序算法篇」
  • Power Apps - 尝试一下PowerApps中的Plan功能
  • 电子电气诊断架构 --- HPC车载诊断
  • 分布式系统中的 Kafka:流量削峰与异步解耦(二)
  • Ubuntu 22.04LTS下安装D435i深度相机的驱动
  • STM32:AS5600
  • XML在线格式化工具
  • 容器技术与Docker环境部署
  • 北京京东,看看难度
  • 机器学习模型:逻辑回归之计算概率
  • PostgreSQL 性能优化与集群部署:PGCE 认证培训实战指南
  • 10分钟撸出高性能网络服务:吃透高性能优化:缓存_锁_系统调用_编译
  • Spring Boot + MyBatis + Vue:从零到一构建全栈应用
  • 大模型在肺癌预测及个性化诊疗方案中的应用研究
  • Excel文件比较器v1.3,html和js写的
  • 海兴网站建设/电脑培训班在哪里有最近的
  • 重庆快速网站建设/it培训班
  • 电子商务网站建设携程/上海职业技能培训机构一览表
  • 包装纸箱怎么做网站/seo培训机构
  • 主网站怎么做熊掌号优化/深圳网络推广公司排名
  • 张家界疫情最新消息今天封城了/台州百度推广优化