码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode(Python)—— 杨辉三角(简单)


    杨辉三角

    概述:给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行。在「杨辉三角」中,每个数是它左上方和右上方的数的和。

    1. 输入: numRows = 5
    2. 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]
    3. 输入: numRows = 1
    4. 输出: [[1]]

    方法一:数学法

    思路:每行数字左右对称,由 1 开始逐渐变大再变小,并最终回到 1。每个数字等于上一行的左右两个数字之和,可用此性质写出整个杨辉三角。

    1. # 数学法
    2. class Solution:
    3. def generate(self, numRows: int) -> List[List[int]]:
    4. ans = []
    5. n = numRows
    6. for i in range(n):
    7. row = []
    8. for j in range(0, i + 1):
    9. if j == 0 or j == i:
    10. row.append(1)
    11. else:
    12. row.append(ans[i - 1][j] + ans[i - 1][j - 1])
    13. ans.append(row)
    14. return ans

    方法二:错位相加

    思路:观察一下规律,发现当前一行只比上一行多了一个元素,最最关键的一点:本行元素等于上一行元素往后错一位再逐个相加。因此我们只要对最后一行单独处理:最后一行首、尾分别添加一个零然后对应位置求和就可以得到新的一行。

    1. # 错位相加
    2. class Solution:
    3. def generate(self, numRows: int) -> List[List[int]]:
    4. n = numRows
    5. if n == 0:
    6. return []
    7. ans = [[1], ]
    8. while len(ans) < n:
    9. row = [i + j for i, j in zip([0] + ans[-1], ans[-1] + [0])]
    10. ans.append(row)
    11. return ans

    总结

    我也在纸上比划了半天,为啥就发现不了这个规律呢?

  • 相关阅读:
    【智能家居】
    C/C++关于main函数参数问题
    图学习初探Paddle Graph Learning 构建属于自己的图【系列三】
    计算机毕业设计ssm基于java网上心理咨询系统50fxl系统+程序+源码+lw+远程部署
    Servlet
    (算法)硬币问题
    使用Python进行云计算:AWS、Azure、和Google Cloud的比较
    c语言练习59:深入理解char类型的取值范围
    保姆级教学安装Linux操作系统,以及Linux的语法入门
    redis过期key的清理/删除策略
  • 原文地址:https://blog.csdn.net/m0_61661179/article/details/127433934
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号