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

python:算法竞赛入门之一

计算 斐波那契数列(Fibonacci sequence),不受长整型位数限制。

编写  fibonacci.py  如下

# -*- coding: utf-8 -*-
""" 计算 斐波那契数列(Fibonacci sequence)"""
import sys
from datetime import datetime# 递归函数定义
def fib(n):if n <=0: return 0if n ==1: return 1if n ==2: return 1return fib(n-1) + fib(n-2)# 将递归改为迭代可以把效能提升不少
def fib1(n):x,y = 0,1while n>0:x,y,n = y,x+y,n-1return x# 通过将计算结果保存到 dict中,后面计算时可以取用,称为备忘方式
known = {0:0, 1:1, 2:1}def fib2(n):if n <=0: return 0if n in known: return known[n]res = fib2(n-1) + fib2(n-2)known[n] = resreturn res# main()
if len(sys.argv) ==2:n = int(sys.argv[1])
else:print(' usage: python fibonacci.py n ')sys.exit(1)if n < 3:print(' input n >= 3 ')
else:print(datetime.now())print('fib1(%d)= %d' % (n, fib1(n)))print(datetime.now())print('fib2(%d)= %d' % (n, fib2(n)))print(datetime.now())

运行 python fibonacci.py 1000

结论:fib1(n) 执行速度比 fib2(n) 快,fib(n) 最慢。

编写  fibonacci.lua  如下

-- 计算 斐波那契数列(Fibonacci sequence)
function fibonacci(n, a, b)if n < 0 then return 0 endif n == 0 thenreturn aelsereturn fibonacci(n-1, b, a+b)end
endif #arg > 0 thenlocal n = tonumber(arg[1])if n > 2 thenlocal result = fibonacci(n, 0, 1)print("fib(n)=", result)elseprint(" must n > 2 ")end
elseprint(" usage: lua fibonacci.lua n ")
end

运行 lua54.exe fibonacci.lua 161

fib(n)= 9217463444206948445

运行  lua54.exe fibonacci.lua 162

fib(n)= -969573230286635304  这个结果溢出了

相关文章:

python:算法竞赛入门之一

计算 斐波那契数列&#xff08;Fibonacci sequence&#xff09;&#xff0c;不受长整型位数限制。 编写 fibonacci.py 如下 # -*- coding: utf-8 -*- """ 计算 斐波那契数列&#xff08;Fibonacci sequence&#xff09;""" import sys from …...

【大数据与云计算】虚拟机安装Linux

前言&#xff1a;使用Linux系统对大数据学习必不可少&#xff0c;本文主要介绍虚拟机安装linux的流程 文章目录 一、 下载VMware二、下载Linux三、安装Linux 一、 下载VMware 官网链接 下载VMware-player&#xff0c;一直下一步安装即可。 二、下载Linux 点击链接直接下载&…...

从零开始编写一个cmake构建脚本

简介 本文档介绍cmake构建脚本编写&#xff0c;包含的一些主要元素和命名规范。 cmake构建脚本编写步骤 cmake构建工具版本要明确 # 命令名字要小写&#xff0c;这条语句要求构建工具至少需要版本为3.12或以上 cmake_minimum_required (VERSION 3.12)工程名及库的版本号明确…...

pringboot2集成swagger2出现guava的FluentIterable方法不存在

错误信息 Description: An attempt was made to call a method that does not exist. The attempt was made from the following location: springfox.documentation.spring.web.scanners.ApiListingScanner.scan(ApiListingScanner.java:117) The following method did not ex…...

进程线程的关系

举个例子 滑稽老师吃100只鸡 如何加快滑稽老师吃鸡的效率&#xff1f;&#xff1f; 有一个方案&#xff0c;搞两个房间&#xff0c;两个滑稽老师 一个滑稽吃50只鸡&#xff0c;速度一定会大幅度增加 多进程的方案 创建新的进程 就需要申请更多的资源&#xff08;房间和…...

一些 VLP 下游任务的相关探索

目录 一、Image-Text Retrieval (ITR , 图像文本检索) 任务目的&#xff1a; 数据集格式 训练流程 evaluation流程 实际使用推测猜想 二、Visual Question Answering &#xff08;VQA &#xff0c; 视觉问答&#xff09; 任务目的 数据集格式 训练流程 demo以及评估流…...

【opencv】示例-pca.cpp PCA图像重建演示

// 加载必要的头文件 #include <iostream> // 用于标准输入输出流 #include <fstream> // 用于文件的输入输出 #include <sstream> // 用于字符串的输入输出流操作#include <opencv2/core.hpp> // OpenCV核心功能的头文件 #include "o…...

C语言中的编译和链接

系列文章目录 文章目录 ​编辑 系列文章目录 文章目录 前言 一、 翻译环境和运行环境 二、 翻译环境 2.1 编译 2.1.1 预处理 2.1.2 编译 2.1.2.1 词法分析 : 2.1.2.2 语法分析 2.1.2.3 语义分析 2.1.3 汇编 2.2 链接 三、运行环境 前言 在我们平常的写代码时&#xff0c;我们很…...

如何将三方库集成到hap包中——通过IDE集成cmak构建方式的C/C++三方库

简介 cmake构建方式是开源三方库的主流构建方式。DevEco Studio目前以支持cmake的构建方式。本文将通过在IDE上适配cJSON三方库为例讲来解如何在IDE上集成cmake构建方式得三方库。 创建工程 在开发进行三方库适配以及napi接口开发前&#xff0c;我们需要创建一个三方库对应的…...

Towards Street-Level Client-Independent IP Geolocation(2011年)(第二部分)

被引次数:306 Wang Y, Burgener D, Flores M, et al. Towards {Street-Level}{Client-Independent}{IP} Geolocation[C]//8th USENIX Symposium on Networked Systems Design and Implementation (NSDI 11). 2011. 接着Towards Street-Level Client-Independent IP Geolocati…...

软件测试过程和测试生命周期

众所周知&#xff0c;软件生命周期包括&#xff0c;需求阶段、设计阶段、设计构建阶段、测试周期阶段、最后测试、实施阶段、最后运维和维护验收。每个阶段都需要在软件开发的生命周期中从前一阶段交付。需求转化为设计&#xff0c;设计转化为开发和开发成测试&#xff0c;经过…...

python-study-day1

ps&#xff1a;前言 可做毕设&#xff0c;html&#xff0c;web&#xff0c;app&#xff0c;小程序&#xff0c;bug修改&#xff0c;可加急 作者自述 作为一名前端开发工程师&#xff0c;这个大环境不好的情况下&#xff0c;我试过我前端接单子但是没有后端&#xff0c…...

【Apache2】彻底删除 Apache2 服务器

要彻底删除 Apache2 服务器&#xff0c;需要卸载 Apache2 软件包并删除其配置文件和数据文件。在 Ubuntu 上&#xff0c;可以按照以下步骤来完成&#xff1a; 停止 Apache2 服务&#xff1a; sudo systemctl stop apache2卸载 Apache2 软件包&#xff1a; sudo apt-get purge a…...

C#:成绩等级转换

任务描述 本关任务&#xff1a;给出一百分制成绩&#xff0c;要求输出成绩等级‘A’、‘B’、‘C’、‘D’、‘E’。 90分以上为A 80-89分为B 70-79分为C 60-69分为D 60分以下为E&#xff0c;如果输入数据不在0~100范围内&#xff0c;请输出一行&#xff1a;“Score is error!”…...

每日OJ题_01背包③_力扣494. 目标和(dp+滚动数组优化)

目录 力扣494. 目标和 问题解析 解析代码 滚动数组优化代码 力扣494. 目标和 494. 目标和 难度 中等 给你一个非负整数数组 nums 和一个整数 target 。 向数组中的每个整数前添加 或 - &#xff0c;然后串联起所有整数&#xff0c;可以构造一个 表达式 &#xff1a; …...

vue3+element plus图片预览点击按钮直接显示图片的预览形式

1 需求 直接上需求&#xff1a; 我想要直接点击下面这个“预览”按钮&#xff0c;然后呈现出预览图片的形式 ok&#xff0c;需求知道了&#xff0c;下面让我们来看看如何实现吧 ~ 2 实现 template部分 <el-buttontype"primary"size"small"click&qu…...

GAMS104 现代游戏引擎 2

渲染的难点可以分为一下三部分&#xff1a;如何计算入射光线、如何考虑材质以及如何实现全局光照。 渲染的难点之一在于阴影&#xff0c;或者说是光的可见性。如何做出合适的阴影效果远比想象中要难得多&#xff0c;在实践中往往需要通过大量的技巧才能实现符合人认知的阴影效…...

spring boot学习第十七篇:OAuth2概述及使用GitHub登录第三方网站

0. 导言 我们在浏览器上可以访问成百上千个网站&#xff0c;使用每个网站的服务一般都要先注册账号&#xff0c;那么我们为了更好地记忆&#xff0c;一般都会在多个网站使用相同的账号和密码进行注册。那么问题就来了&#xff0c;如果在你注册的网站中有某些个网站的系统设计不…...

基于springboot的电影评论网站系统源码数据库

基于springboot的电影评论网站系统源码数据库 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了电影评论网站的开发全过程。通过分析电影评论网站管理的不足&#xff0c;创建了一个计算机管理电影评论网站的方案。文…...

javaScript手写专题——实现instanceof/call/apply/bind/new的过程/继承方式

目录 原型链相关 手写instanceof 实现一个_instance方法&#xff0c;判断对象obj是否是target的实例 测试 手写new的过程 实现一个myNew方法&#xff0c;接收一个构造函数以及构造函数的参数&#xff0c;返回构造函数创建的实例对象 测试myNew方法 手写类的继承 ES6&…...

RC 滤波截止频率与滤波原理详解

一、先搞懂最核心的问题&#xff1a;滤波到底 "滤" 的是什么&#xff1f;滤波不是 "切掉" 某个频率的信号&#xff0c;而是对不同频率的信号进行选择性衰减 **。**我们想要的信号&#xff08;有用信号&#xff09;&#xff1a;让它尽可能无衰减地通过电路我…...

Arm MAP性能分析工具使用指南与优化技巧

1. Arm MAP性能分析工具概述在现代高性能计算(HPC)领域&#xff0c;性能分析工具已成为开发者优化应用程序的关键利器。Arm MAP作为一款专业的跨平台性能分析工具&#xff0c;能够帮助开发者深入理解应用程序的运行行为&#xff0c;定位性能瓶颈&#xff0c;并针对性地进行优化…...

PowerToys汉化完整指南:3分钟让Windows效率工具说中文

PowerToys汉化完整指南&#xff1a;3分钟让Windows效率工具说中文 【免费下载链接】PowerToys-CN PowerToys Simplified Chinese Translation 微软增强工具箱 自制汉化 项目地址: https://gitcode.com/gh_mirrors/po/PowerToys-CN 你是否曾经因为PowerToys的英文界面而感…...

ChromaControl:如何用智能技术终结RGB设备控制混乱局面

ChromaControl&#xff1a;如何用智能技术终结RGB设备控制混乱局面 【免费下载链接】ChromaControl 3rd party device lighting support for Razer Synapse. 项目地址: https://gitcode.com/gh_mirrors/ch/ChromaControl 想象一下这样的场景&#xff1a;你的桌面上摆放着…...

PyQt5实战:从Designer拖拽到打包exe,手把手打造你的第一个多页面桌面应用

PyQt5实战&#xff1a;从Designer拖拽到打包exe&#xff0c;手把手打造你的第一个多页面桌面应用 在数字化浪潮席卷各行各业的今天&#xff0c;图形用户界面&#xff08;GUI&#xff09;开发已成为程序员必备技能之一。而PyQt5作为Python最强大的GUI框架&#xff0c;凭借其丰富…...

【claude code agent 实践7】后台任务机制深度解析: 从S02到S08的演进

后台任务机制深度解析 文章目录后台任务机制深度解析&#x1f504; s02 vs s08 核心变化对比&#x1f50d; 新增核心逻辑详解1. BackgroundManager类&#xff08;后台任务管理器&#xff09;2. agent_loop关键变化 - 每次LLM调用前排空队列&#x1f4ca; 后台任务完整工作流程图…...

嵌入式视觉成本降至百元级:技术民主化如何重塑工业物联网应用

1. 工业物联网与嵌入式视觉&#xff1a;从昂贵壁垒到百元级应用的演进 提到物联网&#xff0c;很多人脑子里蹦出来的可能是家里的智能音箱、手腕上的健康手环&#xff0c;或者能远程控制的冰箱。没错&#xff0c;消费和医疗领域确实是物联网最显眼的舞台。但作为一名在工业自动…...

AntiDupl.NET:高效智能的重复图片检测与清理解决方案

AntiDupl.NET&#xff1a;高效智能的重复图片检测与清理解决方案 【免费下载链接】AntiDupl A program to search similar and defect pictures on the disk 项目地址: https://gitcode.com/gh_mirrors/an/AntiDupl 你是否曾因电脑中堆积如山的重复图片而感到困扰&#…...

如何用ComfyUI MixLab插件重塑你的AI创作流程:5个颠覆性应用场景

如何用ComfyUI MixLab插件重塑你的AI创作流程&#xff1a;5个颠覆性应用场景 【免费下载链接】comfyui-mixlab-nodes Workflow-to-APP、ScreenShare&FloatingVideo、GPT & 3D、SpeechRecognition&TTS 项目地址: https://gitcode.com/gh_mirrors/co/comfyui-mixla…...

IGBT驱动技术革新:SCALE-iDriver磁隔离方案解析

1. IGBT驱动技术演进与SCALE-iDriver的突破在电力电子系统中&#xff0c;IGBT&#xff08;绝缘栅双极型晶体管&#xff09;作为核心功率开关器件&#xff0c;其驱动电路的性能直接决定了整个系统的效率和可靠性。传统IGBT驱动方案主要面临三大技术瓶颈&#xff1a;首先是隔离技…...