洛谷题单3-P1720 月落乌啼算钱(斐波那契数列)-python-流程图重构

题目描述

给定一个整数 N N N,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零(参见样例 2)。

输入格式

一个整数 N N N。

输出格式

一个整数,表示反转后的新数。

输入输出样例

输入

复制代码
123

输出

复制代码
321

说明/提示

【数据范围】

-1,000,000,000\\leq N\\leq 1,000,000,000

方式-根据表达式计算

代码

python 复制代码
class Solution:
    @staticmethod
    def oi_input():
        """从标准输入读取数据"""
        num = int(input())
        return num

    @staticmethod
    def oi_test():
        """提供测试数据"""
        return 6

    @staticmethod
    def solution(num):
        '''根据表达式计算值 大范围可能会有精度问题'''
        from math import sqrt

        sqrt5 = sqrt(5)
        left = (1 + sqrt5) / 2
        right = (1 - sqrt5) / 2
        fn = (left ** num - right ** num) / sqrt5
        print("{0:.2f}".format(fn))


oi_input = Solution.oi_input
oi_test = Solution.oi_test
solution = Solution.solution

if __name__ == '__main__':
    num = oi_test()
    # num = oi_input()
    solution(num)

流程图

开始 读取输入num 计算sqrt(5), 黄金分割比例 计算左项 (1+√5)/2 的num次方 计算右项 (1-√5)/2 的num次方 (左项 - 右项)/sqrt(5) 格式化为两位小数输出 结束

方式-记忆化递归

代码

python 复制代码
class Solution:
    @staticmethod
    def oi_input():
        """从标准输入读取数据"""
        num = int(input())
        return num

    @staticmethod
    def oi_test():
        """提供测试数据"""
        return 6

    @staticmethod
    def solution(num):
        '''记忆化递归'''
        from functools import lru_cache

        @lru_cache(maxsize=None)  # 使用缓存装饰器,避免重复计算
        def fibonacci(num):
            if num == 0:
                return 0
            elif num == 1:
                return 1
            return fibonacci(num - 1) + fibonacci(num - 2)

        result = fibonacci(num)
        print("{0:.2f}".format(result))


oi_input = Solution.oi_input
oi_test = Solution.oi_test
solution = Solution.solution

if __name__ == '__main__':
    num = oi_test()
    # num = oi_input()
    solution(num)

流程图

是 否 是 否 开始 输入num num是否为0? result = 0 num是否为1? result = 1 初始化a=0, b=1 循环2到num a, b = b, a+b 更新后b的值 循环结束 result = b 格式化输出两位小数 结束

相关推荐
2301_776681654 分钟前
【用「概率思维」重新理解生活】
开发语言·人工智能·自然语言处理
熊大如如29 分钟前
Java 反射
java·开发语言
万能程序员-传康Kk1 小时前
旅游推荐数据分析可视化系统算法
算法·数据分析·旅游
PXM的算法星球1 小时前
【并发编程基石】CAS无锁算法详解:原理、实现与应用场景
算法
ll7788111 小时前
C++学习之路,从0到精通的征途:继承
开发语言·数据结构·c++·学习·算法
烨然若神人~1 小时前
算法第十七天|654. 最大二叉树、617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树
算法
爱coding的橙子1 小时前
每日算法刷题Day2 5.10:leetcode数组1道题3种解法,用时40min
算法·leetcode
我不想当小卡拉米1 小时前
【Linux】操作系统入门:冯诺依曼体系结构
linux·开发语言·网络·c++
teacher伟大光荣且正确1 小时前
Qt Creator 配置 Android 编译环境
android·开发语言·qt
炎芯随笔1 小时前
【C++】【设计模式】生产者-消费者模型
开发语言·c++·设计模式