用python实现杨辉三角的几种不同方式

article/2025/8/28 3:31:37

杨辉三角的概念

比较详细的知识可以看这里,在杨辉三角中,每个数是它左上方和右上方的数的和。
在这里插入图片描述

          1/ \1   1/ \ / \1   2   1/ \ / \ / \1   3   3   1/ \ / \ / \ / \1   4   6   4   1/ \ / \ / \ / \ / \
1   5   10  10  5   1

解法1:动态规划

  • 思路:
    如果能够知道一行杨辉三角,我们就可以根据每对相邻的值轻松地计算出它的下一行。
  • 解法:
    首先,我们会生成整个 triangle 列表,三角形的每一行都以子列表的形式存储。然后,我们会检查行数为0的特殊情况,否则我们会返回[1]。如果行数大于1,那么我们用[1]作为第一行来初始化,所以可以得到如下程序:
    def generate(num_rows):triangle = []for row_num in range(num_rows):# 初始化zhenghangsrow = [None for _ in range(row_num+1)]# 将第一个数和最后一个数设置为1row[0], row[-1] = 1, 1for j in range(1, len(row)-1):row[j] = triangle[row_num-1][j-1] + triangle[row_num-1][j]triangle.append(row)return triangle

解法2:生成器

本质上和解法1的思想一致,但是可以使用生成器来都程序进行改写,程序如下:

    def generate(num_rows):def triangles():t = [1]while True:yield ts = [0] + tt = t + [0]for i in range(len(s)):t[i] = s[i] + t[i]result = []n = 0for t in triangles():result.append(t)n = n + 1if n == numRows:breakreturn result

但是奇怪的是,我将这个程序通过leetcode进行提交,却得到了超时的错误,按理说使用生成器进行操作应该是更快才是,但是反而慢了?不得其解,如果有了解的同学欢迎告知。

解法三:数学公式

运用杨辉三角的公式:第n行第m个数可表示为C(n-1,m-1) = (n - 1)!/(m - 1)!*(n - m - 2)!

from math import factorial as f def generate(num_rows):res = [[] for _ in range(numRows)] if not numRows: return []      for i in range(numRows): for j in range(i + 1): res[i].append(f(i)//(f(j)*f(i - j)))return res

在python中如果利用足够的python特性可以一行程序解决这个问题:

    def generate(num_rows):return [[comb(i,j) for j in range(i+1)] for i in range(numRows)]

其中comb函数是python3.8 新引入的特性,主要是为了计算C(n, m),也就是从n中取出m个数的概率


http://chatgpt.dhexx.cn/article/R8bRv4aP.shtml

相关文章

【杨辉三角python】

文章目录 杨辉三角实现方法(Python) 一、杨辉三角是什么?二、杨辉三角解法 杨辉三角实现方法(Python) 一、杨辉三角是什么? 杨辉三角,是二项式系数在三角形中的一种几何排列,中国南…

Python实现杨辉三角(2种实现方案)

杨辉三角形,又称贾宪三角形、帕斯卡三角形,是二项式系数在三角形中的一种几何排列。 下图显示了杨辉三角的前 7 行: 递归打印杨辉三角 杨辉三角形中的数,正是(xy)的 N 次方幂展开式各项的系数,下面以递归的方法来打印…

【Python实现杨辉三角】

目录 什么是杨辉三角 杨辉三角解法 1. 定义法 2. 计算杨辉三角 补0法 3. 杨辉三角,对称法 4. 杨辉三角,单列表方法 5.列表嵌套(二维数组) 6. 新旧两行,一次性开辟新行 7.yield函数 8.zip函数 参考资料链接&…

c++自定义函数

对于小型应用程序来说不设计自定义函数完全可行,但随着程序越来越大,越来越复杂,实现的功能越来越多,如果不使用函数,main函数将变的越来越复杂越来越雍肿越来越令人难懂,而在更改程序的每一个功能的时候&a…

C++ 自定义函数

C的函数分两种: 今天,我们就来讲一下自定义函数。 好了,自定义函数讲完了,若想了解其他关于自定义函数的内容,请点击下面方框: C递归算法_闪耀的天狼星的博客-CSDN博客_c递归算法汉诺塔大家都玩过吧&#…

C语言:自定义函数实现对字符串的复制

#include <stdio.h> void f(char*str1,char*str2)//函数名为f&#xff0c;自定义字符串连接函数 {int i0;while(str2[i]!0) {str1[i]str2[i];//把b复制到a中i;}str1[i]\0;//添加字符串结束符 } int main() {char a[100],b[100];puts("请输入字符串:\n");gets…

C语言之自定义函数(综合)

//设定一个函数&#xff0c;来比较两个数之间的较大值 int get_max(int x, int y) {int z 0;if (x > y)z x;elsez y;return z;} int main() {int a 10;int b 20;int maxget_max(a, b);printf("%d", max);return 0; } //函数返回类型的地方写出&#xff1a;vo…

[C语言] 函数:库函数--自定义函数--函数的调用--练习--详解<个人>------(1)

文章目录 前言一. 函数是什么&#xff1f;二. C语言中函数的分类三. 库函数四. 自定义函数五. 函数的调用六. 练习总结 前言 本节内容主要记录函数的相关内容&#xff0c;其中包括&#xff1a;库函数&#xff0c;自定义函数&#xff0c;函数的调用&#xff0c;函数的习题练习。…

C语言中的函数 | 库函数和自定义函数

写在前面: 今天我们需要学习和了解的是C语言中的函数,其中C语言的函数划分为库函数和自定义函数两种.接下来我们一起探究两者之间的关系. 一.C语言中函数的分类 库函数自定义函数 二.库函数 库函数到底是什么呢? 顾名思义,可以通俗的理解为库里面的函数.这些函数都是频繁使…

c++自定义函数简单介绍

大家好&#xff0c; 今天给大家介绍一下自定义函数。 如有错误请在评论区指出 正文&#xff1a; 1.简单介绍&#xff1a; 函数是一组一起执行一个任务的语句。每个 C 程序都至少有一个函数&#xff0c;即主函数 main() &#xff0c;所有简单的程序都可以定义其他额外的函数…

C语言入门系列 - 自定义函数

C语言入门系列 - 自定义函数 第一节 C 语言基础以及基本数据类型 第二节 C 语言运算符 第三节 C 语言控制语句 第四节 C 语言自定义函数 第五节 C 语言修饰变量的关键字 第六节 C 语言构造数据类型–数组 第七节 C 语言字符串 第八节 C 语言指针 第九节 指针与函数、指针函数、…

C语言-函数(自定义函数)

C语言中函数的分类&#xff1a; 1 库函数 2 自定义函数 自定义函数 如果库函数能干所有的事情&#xff0c;那还要程序员做什么&#xff1f; 所以更重要的是自定义函数 函数的组成&#xff1a; ret_type fun_name (part1) { statement; //语句项 &#xff08;函数体&…

C语言自定义函数使用

补充1&#xff1a;优先级&#xff0c;解答问题区分*p,*p0,*p0 <1>.首先要理解前后置的区别&#xff0c;前置&#xff0c;先计算后使用&#xff1b;后置&#xff0c;先使用后计算。 可用示例理解&#xff1a; <2>.其次要理解操作符的优先级 优先级从高到低&#…

C语言【库函数与自定义函数】详解

文章目录 一.什么是函数二.库函数1. 什么是库函数2. 为什么会有库函数&#xff1f;3.使用库函数的注意事项4.对学习库函数的建议 三.自定义函数1.什么是自定义函数2.自定义函数举例 一.什么是函数 提起函数&#xff0c;我们可能并不陌生&#xff0c;我们可能会联想到数学中的函…

C语言中的函数(重点介绍自定义函数)

C语言中的函数分为库函数和自定义函数&#xff0c;本篇重点介绍自定义函数中的函数调用 函数由一个或多个语句块组成&#xff0c;负责完成某项特定任务&#xff0c; 相较于其他代码&#xff0c;具有相对的独立性&#xff0c;一般会有返回值和输入参数&#xff0c;提供对过程的封…

C语言自定义函数的声明

C语言函数为什么要声明呢&#xff1f;我们在创建自定义函数的都知道要将自定义子函数放在主函数前面那么是为什么呢&#xff1f;可不可以不放在前面呢&#xff1f;小问号你是不是也一样有很多朋友呢&#xff1f; 答案是可以不把我们自己的自定义子函数放在前面&#xff1f;但是…

c语言函数详解1——自定义函数

这篇文章理论性知识比较多&#xff0c;不过对于初学者对于函数的理解会有更深层次的帮助 目录 c语言的函数——子程序 自定义函数 c语言的函数——子程序 *是大型程序中的某部分代码&#xff0c;由一个或者多个语句组成&#xff0c;她负责完成某项特定的任务&#xff0c;相较…

自定义函数

目录 一、自定义函数 二、函数参数 、传值调用和传址调用 2、1 传值调用 2、2 传址调用 三、函数的嵌套和链式访问 四、函数递归 一、自定义函数 C语言中有两类函数&#xff0c;一类是库函数&#xff0c;另外一类是自定义函数。自定义函数从字面意思上理解就是自…

C语言自定义函数

函数定义 return_type function_name([datatype1 arg1],[datatype1 arg2],...) { //函数体 } 函数三要素 返回值类型 函数名 参数列表 自定义函数的完整写法 #include <stdio.h> // 函数原型 int sum(int,int); // 调用函数 int main() { int sum(); } // 函数定义 i…

学习pyqt 继承中self的疑问

前面学习了&#xff0c;面对对象编程&#xff0c;继承&#xff0c;有了一些理解。继续学习pyqt5 看到下面有了一些疑问。 import sys from PyQt5.QtWidgets import QApplication, QWidget from PyQt5.QtGui import QIconclass Example(QWidget):def __init__(self):super().…