python-SZ斐波那契数列/更相减损数

news/2024/9/22 2:56:01/

一:SZ斐波那契数列
题目描述
你应该很熟悉斐波那契数列,不是吗?现在小理不知在哪里搞了个山寨版斐波拉契数列,如下公式:
F(n)=
{
$\ \ \ \ \ \ \ \ \ \ \ \ $ a,( n=1)
$\ \ \ \ \ \ \ \ \ \ \ \ $ b,( n=2)
$\ \ \ \ \ \ \ \ \ \ \ \ $ F(n−1)+F(n−2),(n>2并且n是奇数)
$\ \ \ \ \ \ \ \ \ \ \ \ $ F(n−1)+F(n−2)+F(n−3)(n>2并且n是偶数)
}
这里 a 和 b 是定值,现给出 a,b 和 n,你的任务是计算 F(n)。
输入格式
输入共 T+1 行。
第一行有一个正整数 T,表示测试实例的个数。
接下来 TT行,每行一个测试实例,每个测试实例包括三个正整数 a,b 和 n。
输出格式
对于每个测试实例,输出一行包含一个正整数 F(n)。
样例输入输出
样例输入

2
1 2 3
1 3 6
样例输出
3
24
数据范围
对于 100% 的数据,保证T≤10,a,b≤10,n≤30。
来源/分类(难度系数:二星
模拟 


完整代码展示:
def F(a,b,n):
       list_1=[a,b,a+b]
       begin=3
       while begin<n+1:
              if (begin+1)%2==0:                                               list_1.append(list_1[-1]+list_1[-2]+list_1[-3])
              elif (begin+1)%2==1:
                   list_1.append(list_1[-1]+list_1[-2])
              begin+=1
         return list_1[n-1]
m=int(input())
list_2=[]
for i in range(m):
      list_3=list(map(int,input().split()))
      list_2.append(list_3)
for i in range(0,len(list_2)):
      print(F(list_2[i][0],list_2[i][1],list_2[i][2]))

python">def F(a,b,n):list_1=[a,b,a+b]begin=3while begin<n+1:if (begin+1)%2==0:list_1.append(list_1[-1]+list_1[-2]+list_1[-3])elif (begin+1)%2==1:list_1.append(list_1[-1]+list_1[-2])begin+=1return list_1[n-1]
m=int(input())
list_2=[]
for i in range(m):list_3=list(map(int,input().split()))list_2.append(list_3)
for i in range(0,len(list_2)):print(F(list_2[i][0],list_2[i][1],list_2[i][2]))


代码解释:
“def F(a,b,n):
        list_1=[a,b,a+b]
        begin=3
        while begin<n+1:
               if (begin+1)%2==0:
         list_1.append(list_1[-1]+list_1[-2]+list_1[-3])
               elif (begin+1)%2==1:
                    list_1.append(list_1[-1]+list_1[-2])
               begin+=1
        return list_1[n-1]                                           ”,按照题意自定义一个函数F(),传递三个形参a,b,n,即斐波那契函数的第1项a,2项b和所求项n。(建立一个空列表list_1,将a,b,a+b分别作为list_1的第1,2,3项。令begin为循环密码子,当begin<n+1时:如果begin+1能被2整除,则将list_1后三项和添加进list_1末尾,否则将list_1后两项添加进list_1末尾。每循环一次,begin+1,直至begin==n+1,跳出整个while循环,最终返回list_1的末尾元素值)。
“m=int(input()) ”,导入用户输入的测试实例的个数m。
“list_2=[]
 for i in range(m):
       list_3=list(map(int,input().split()))
       list_2.append(list_3)                      ”,建立一个空列表list_2,循环m次:导入用户输入的a,b,n,并将其储存在列表list_3中,接着将list_3添加进list_2中。
“for i in range(0,len(list_2)):
       print(F(list_2[i][0],list_2[i][1],list_2[i][2])) ”,遍历list_2中的元素,将list_2[i][0]~list_2[i][2]作为实参传递进F()函数,并打印F()函数返回值。


运行效果展示:

a95024b579964f93b6816f27ede8e5b9.jpg

04380ed47b58467980e686c92e0df9cb.jpg 

 

 

 

 

二:更相减损数:
题目描述
利用更相减损术求两个整数的最大公约数,即每次将较大的数变成大数减去小数的值。
输入格式
输入两个正整数 m , n 。
输出格式
输出一个整数。
样例输入输出
样例输入

4 6
样例输出
2
数据范围
对于 100% 的数据,保证 1≤m,n≤106 。
来源/分类(难度系数:二星
递归 最大公约数 数学 


完整代码展示:

x,y=map(int,input().split())
if x > y:
     x,y=y,x
for fac in range(x,0,-1):
      if x % fac == 0 and y % fac == 0 :
           print('{}'.format(fac))
           break

python">x,y=map(int,input().split())
if x > y:x,y=y,x
for fac in range(x,0,-1):if x % fac == 0 and y % fac == 0 :print('{}'.format(fac))break


代码解释:
“x,y=map(int,input().split())
 if x > y:
      x,y=y,x                             ”,导入用户输入的两个正整数x,y,并判断x,y的·大小关系:如果x,y,则将x,y交换值(即保证x为x,y中最小值)。
“for fac in range(x,0,-1):
        if x % fac == 0 and y % fac == 0 :
             print('{}'.format(fac))
             break                                         ”,依次遍历x~1的所有数fac,并判断x,y是否同时能被fac整除,如果是:则打印fac,终止循环。


运行效果展示:

24bc38b3781e45819c459c21d1e592a7.jpg

 7937fe8bc6f04b45bede570b015a06ca.jpg

               (声明:以上内容均为原创) 

 

 


http://www.ppmy.cn/news/1528665.html

相关文章

【JavaScript】数据结构之堆

什么是堆&#xff1f; 堆都能用树来表示&#xff0c;一般树的实现都是利用链表。而 二叉堆 是一种特殊的堆&#xff0c;它用完全二叉树来表示&#xff0c;却可以利用数组实现。平时使用最多的是二叉堆。二叉堆易于存储&#xff0c;并且便于索引。堆数据结构像树&#xff0c;但…

前端开发深入了解性能优化

前置知识 图片预加载 图片预加载是指在用户访问网页时&#xff0c;提前加载一些图片资源&#xff0c;以便在用户需要查看这些图片时能够更快地显示 原理&#xff1a; 提前请求&#xff1a;在页面加载时&#xff0c;浏览器会发送请求获取图片资源。预加载通常使用 JavaScrip…

OpenGL 原生库6 坐标系统

概述 为了将坐标从一个坐标系变换到另一个坐标系&#xff0c;我们需要用到几个变换矩阵&#xff0c;最重要的几个分别是模型(Model)、观察(View)、投影(Projection)三个矩阵。我们的顶点坐标起始于局部空间(Local Space)&#xff0c;在这里它称为局部坐标(Local Coordinate)&a…

【docker】命令之容器操作

一、前言 在上篇博客介绍了关于如何从应用市场&#xff0c;下载镜像后&#xff0c;对镜像的相关操作了。这篇博客呢我们就要讲解我们把镜像下载下来了&#xff0c;启动这个镜像后&#xff0c;就是我们说的容器了&#xff0c;那么容器的具体操作又有那些呢&#xff1f; 二、容器…

ResNeXt学习

1. 模型介绍 ResNeXt是由何凯明团队在2017年CVPR会议上提出来的新型图像分类网络。ResNeXt是ResNet的升级版&#xff0c;在ResNet的基础上&#xff0c;引入了cardinality的概念&#xff0c;类似于ResNet&#xff0c;ResNeXt也有ResNeXt-50&#xff0c;ResNeXt-101的版本。那么…

武汉凯迪正大—变压器空负载特性参数测试仪 变压器容量及损耗参数测试仪

KDBR-N 变压器容量测试仪具有体积小巧、操作简单、使用方便等优点&#xff0c;并升级了内部处理器、数据采集系统、国标数据&#xff0c;使仪器可用范围更宽&#xff0c;测试精度更高。 KDBR-N 变压器容量测试仪包含了变压器容量、变压器空载损耗、变压器负载损耗及其代号水平…

JVM堆介绍

堆 堆是Java虚拟机中用于存储对象实例和数组的内存区域&#xff0c;它是Java程序运行时数据区的核心部分&#xff0c;负责存储和管理几乎所有的对象数据。 一、JVM堆介绍 今天&#xff0c;我们将深入探索Java堆的奥秘。它是Java虚拟机中一个非常关键的内存区域。让我们一起揭…

Windows系统通过部署wsl + Goland进行跨平台开发

1.背景 近期项目中因为用到了 Golang库中的 "log/syslog" 包,而这个包是禁止在windows平台上编译的. 并且在windows环境上开发也会有诸多不便,如执行makefile文件的make命令,本地开发环境中docker,etcd,redis的搭建等等,而这些通过部署wsl去搭建一个linux环境就很可以…