利用python实现二分法和斐波那契序列
2024-10-11 13:18:36
利用python实现二分法:我的实现思路如下
1、判断要查找的值是否大于最大值,如果大于则直接返回False
2、判断要查找的值是否小于最小值,如果小于则直接返回False
3、如果要查找的值在最大值和最小值之间,则进入循环
a、首先序列的长度要大于1,然后获取序列中间一个值的大小
b、然后和要查找的值做比较,如果相等,则直接返回True,如果不相等,则判断如果中间的值大于要查找的值,则说明要查找的值在该中间值的左边,如果中间的值小于要查找的值,则说明要查找的值在中间的值的右边
c、最后如果序列的长度为1,则直接判断序列的值和要查找的值是否相等即可
def f1(src_list,find_n):
if find_n > src_list[-1]: #判断find_n是否大于最大值,如果大于则直接返回
s = "%s is not finded" % (find_n)
print(s)
return False
if find_n < src_list[0]: #判断find_n是否小于最小值,如果小于则直接返回
s = "%s is not finded" % (find_n)
print(s)
return False
else: #只有find_n在最大值和最小值之间,才进入函数
mid = int(len(src_list)/2)
if len(src_list) > 1:
if src_list[mid] > find_n:
print("%s in left" %(find_n))
mid_list = src_list[0:mid]
f1(mid_list,find_n)
elif src_list[mid] < find_n:
print("%s in right" %(find_n))
mid_list = src_list[mid:]
f1(mid_list,find_n)
else:
print("%s is finded" %(find_n))
return True
if len(src_list) == 1:
if src_list[0] == find_n:
s = "%s is finded" % (find_n)
print(s)
return True
else:
s = "%s is not finded" % (find_n)
print(s)
return False
data = list(range(0,10,3))
f1(data,-1)
下面我们在来实现以下斐波那契序列
# 0,1,1,2,3,5,8,13,21,44,65,109
第三个数是前面2个数之和,代码如下
def f1(a,b,stop):
if a == stop:
print(a)
return True
elif b == stop:
print(a,b,sep=" ",end="\n")
return True
elif a > stop:
print("无效的输入")
return False
else:
if a == 0:
print(a,b,sep="\n")
c = a + b
print(c)
if c < stop:
f1(b,c,stop) f1(0,1,144)
结果如下
0
1
1
2
3
5
8
13
21
34
55
89
144
最新文章
- 《2016ThoughtWorks技术雷达峰会----雷达新趋势》
- RPC和Socket,RMI和RPC之间的关系
- python学习之——爬取网页信息
- asp.net将内容导出到Excel,Table表格数据(html)导出EXCEL
- 十二 个经典 Linux 进程管理命令介绍
- Create Function
- <;%%>;与<;%#%>;与<;%=%>;
- Auto Updating the exe from a network location when application starts z
- git 添加忽略文件
- 为什么和其他语言相比C语言是快速的语言
- jQuery中,$.extend,$obj.extend和$.fn.extend三者的区别
- 【请求之密】payload和formData有什么不同?
- Distance on the tree(数剖 + 主席树)
- javac编译错误: 编码UTF8/GBK的不可映射字符
- Java中的forin语句
- Kubernetes Master节点灾备恢复操作指南---升级版
- 客户端对象模型之列表数据导出到Excel
- Linux 添加普通用户到 sudoers 文件
- JavaScript动态加载js文件
- jquery关于select框的取值和赋值
热门文章
- sklearn 线性模型使用入门
- Win10巧用自带输入法轻松打出特殊字符
- Linux中make, make install命令分别是什么
- (转)USB中CDC-ECM的了解和配置
- Python的collections模块中namedtuple结构使用示例
- Kafka 基本原理
- 20180130之PYTHON学习笔记【PYTHON3写个自动听课功能】
- 网络命令ping/netstat/ipconfig/arp/tracert/nbstat
- 《GPU高性能编程CUDA实战》附录三 关于book.h
- Git 代码版本还原方法