博客
关于我
Leetcode每日刷题【易】--Day 1
阅读量:757 次
发布时间:2019-03-23

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

为了将连分数转换为最简分数,我们从最右端开始处理每个系数,逐步向外扩展分子和分母。这种方法确保了我们正确地处理了每个层次的分式。

class Solution:    def fraction(self, cont: List[int]) -> List[int]:        if not cont:            return [0, 1]        numerator = cont[-1]        denominator = 1        for i in range(len(cont) - 2, -1, -1):            next_num = cont[i] * numerator + denominator            next_den = numerator            numerator, denominator = next_num, next_den        return [numerator, denominator]

解决方法:我们的目标是将连分数转换为一个最简分数。连分数的形式通常为 a0 + 1/(a1 + 1/(a2 + ... + 1/an))。为了将这个表达式转换为普通分数形式,我们可以从最右边的系数开始处理,每次扩展上一层的分子和分母。

初始化:

  • 从最右边的系数开始,初始化为分子和分母分别为该数和1。

迭代处理:

  • 从倒数第二个系数开始,逐步处理每个系数。
  • 对于每个系数 a_i,计算新的分子和分母:
    • 新的分子为 a_i * previous_numerator + previous_denominator
    • 新的分母为 previous_numerator
  • 更新当前的分子和分母,继续处理下一个较高的系数。

示例:输入:cont = [3, 2, 0, 2]处理步骤:

  • 初始化:numerator = 2, denominator = 1
  • 处理 i=2(元素 0):
    • numerator = 0 * 2 + 1 = 1
    • denominator = 2
  • 处理 i=1(元素 2):
    • numerator = 2 * 1 + 2 = 4
    • denominator = 1
  • 处理 i=0(元素 3):
    • numerator = 3 * 4 + 1 = 13
    • denominator = 4返回 [13, 4],即最简分数 13/4
  • 代码解释:

    • 初始化分子和分母。
    • 正向遍历反转的列表,逐步更新分子和分母,确保每一步的正确性。
    • 最终返回化简后的分子和分母。

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

    你可能感兴趣的文章
    mysql 常见问题
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>
    Mysql 批量修改四种方式效率对比(一)
    查看>>
    Mysql 报错 Field 'id' doesn't have a default value
    查看>>
    MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
    查看>>
    Mysql 拼接多个字段作为查询条件查询方法
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>
    Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
    查看>>
    mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
    查看>>
    mysql 数据库备份及ibdata1的瘦身
    查看>>
    MySQL 数据库备份种类以及常用备份工具汇总
    查看>>
    mysql 数据库存储引擎怎么选择?快来看看性能测试吧
    查看>>
    MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
    查看>>
    MySQL 数据库的高可用性分析
    查看>>
    MySQL 数据库设计总结
    查看>>
    Mysql 数据库重置ID排序
    查看>>