算法:二分查找(python版)
#!/usr/bin/env python
#coding -*- utf:8 -*-
#二分查找
#时间复杂度O(logn)
#一个时间常量O(1)将问题的规模缩小一半,则O(logn) import random def binary_search(arraya, x, N):
low = 0
high = N-1
notfound = -1 while low<=high:
#这里是//2,写一个/会出错,因为python3中3/2=1.5,3//2=1
middle = (low+high)//2
if(arraya[middle] < x):
low = middle + 1
#注意这里是elif,一开始我写成了if会出错
elif(arraya[middle] > x):
high = middle - 1
else:
return middle
return notfound if __name__=='__main__':
n = int(input("所要生成数组的长度:"))
a = []
for i in range(n):
x = random.choice(range(100))
a.append(x)
#这里排序就用内置的吧!
#列表可以被修改
a.sort()
print("生成的数组(从小到大):",a)
b = int(input("想要查找的x值为:"))
if(binary_search(a, b, n)==-1):
print("所要查找的x不在该数组里!")
else:
print("x的下标为", binary_search(a, b, n))
算法:二分查找(python版)的更多相关文章
- 数据结构和算法设计专题之---二分查找(Java版)
		1.前提:二分查找的前提是需要查找的数组必须是已排序的,我们这里的实现默认为升序 2.原理:将数组分为三部分,依次是中值(所谓的中值就是数组中间位置的那个值)前,中值,中值后:将要查找的值和数组的中值 ... 
- 经典算法二分查找循环实现Java版
		二分查找 定义 二分查找(Binary Search)又称折半查找,它是一种效率较高的查找方法. 要求 (1)必须采用顺序存储结构 (2)必须按关键字大小有序排列 查找思路 首先将给定值K,与表中中间 ... 
- 二分查找-python
		约12年年底的时候,接触了python不到半年的样子,入门是直接实现GUI测试case的.今天面试地平线机器人,发现忘得差不多了- -. 当时的问题是这样的 写一个二分查找是实现,我好像不记得二分查找 ... 
- 南理第八届校赛同步赛-F sequence//贪心算法&二分查找优化
		题目大意:求一个序列中不严格单调递增的子序列的最小数目(子序列之间没有交叉). 这题证明贪心法可行的时候,可以发现和求最长递减子序列的长度是同一个方法,只是思考的角度不同,具体证明并不是很清楚,这里就 ... 
- 二分查找——Python实现
		一.排序思想 二分(折半)查找思想请参见:https://www.cnblogs.com/luomeng/p/10585291.html 二.python实现 def binarySearchDemo ... 
- 莫队算法/二分查找 FZU 2072 Count
		题目传送门 题意:问区间内x的出现的次数分析:莫队算法:用一个cnt记录x的次数就可以了.还有二分查找的方法 代码: #include <cstdio> #include <algo ... 
- 二分查找-Java版
		/** * * 二分查找算法 * * * * @param srcArray 有序数组 * * @param target 查找元素 * * @return srcArray数组下标,没找到返回-1 ... 
- #C++初学记录(贪心算法#二分查找)
		D - Aggressive cows 农夫 John 建造了一座很长的畜栏,它包括N (2 <= N <= 100,000)个隔间,这些小隔间依次编号为x1,...,xN (0 < ... 
- Java-数据结构与算法-二分查找法
		1.二分查找法思路:不断缩小范围,直到low <= high 2.代码: package Test; import java.util.Arrays; public class BinarySe ... 
- Java算法 -- 二分查找
		折半查找,要求待查找的序列有序.每次取中间位置的值与待查关键字比较,如果中间位置的值比待查关键字大,则在前半部分循环这个查找的过程,如果中间位置的值比待查关键字小,则在后半部分循环这个查找的过程.直到 ... 
随机推荐
- H5常用代码:适配方案3
			在H5项目中有一种常见的宣传页,就是那种整屏整屏的,带着炫丽进场动画的移动宣传页,不仅是一种欣赏也起到了很大宣传作用. 对于这种整屏的适配,前面通过视口的兼容处理也是可以做到的,但是在窄屏下会在上下有 ... 
- atitit..代码生成流程图 流程图绘制解决方案 java  c#.net  php v2
			atitit..代码生成流程图 流程图绘制解决方案 java c#.net php v2 1.1. Markdown 推荐,就是代码和flow都不能直接使用.1 1.2. Java code2fl ... 
- Atitit 贝叶斯算法的原理以及垃圾邮件分类的原理
			Atitit 贝叶斯算法的原理以及垃圾邮件分类的原理 1.1. 最开始的垃圾邮件判断方法,使用contain包含判断,只能一个关键词,而且100%概率判断1 1.2. 元件部件串联定律1 1.3. 垃 ... 
- salesforce 零基础学习(三十四)动态的Custom Label
			custom label在项目中经常用到,常用在apex class或者VF里面用来显示help text或者error message.有的时候我们需要用到的信息是动态变化的,那样就需要动态来显示信 ... 
- iOS-数据持久化-属性列表
			属性列表 属性列表文件是一种XML文件,Foundation框架中的数组和字典等都可以于属性列表文件相互转换. NSArray类常用读写属性列表文件的方法: +arrayWithContentsOfF ... 
- js 数组
			js中的数组类似与java中的容器 类型可以不同.长度可变 一.数组的声明 var arr1=new Array();//数组的声明一 var arr2=[1,2,3,true,new Dat ... 
- js判断函数是否存在、判断是否为函数
			代码: <script type="text/javascript"> //判断是否为函数 try { if(typeof FunName === "func ... 
- Java基础-继承-编写一个Java应用程序,设计一个汽车类Vehicle,包含的属性有车轮个数 wheels和车重weight。小车类Car是Vehicle的子类,其中包含的属性有载人数 loader。卡车类Truck是Car类的子类,其中包含的属性有载重量payload。每个 类都有构造方法和输出相关数据的方法。最后,写一个测试类来测试这些类的功 能。
			#29.编写一个Java应用程序,设计一个汽车类Vehicle,包含的属性有车轮个数 wheels和车重weight.小车类Car是Vehicle的子类,其中包含的属性有载人数 loader.卡车类T ... 
- 类的继承和多态性-编写Java应用程序,定义Animal类,此类中有动物的属性:名称 name,腿的数量legs,统计动物的数量 count;方法:设置动物腿数量的方法 void setLegs(),获得腿数量的方法 getLegs(),设置动物名称的方法 setKind(),获得动物名称的方法 getKind(),获得动物数量的方法 getCount()。定义Fish类,是Animal类的子类,
			编写Java应用程序,定义Animal类,此类中有动物的属性:名称 name,腿的数量legs,统计动物的数量 count;方法:设置动物腿数量的方法 void setLegs(),获得腿数量的方法 ... 
- 前端优化-Img与background
			当img 遇到 background,这个世界就是这么小~~~~~ 1 从解析机制看 Img属于html标签,background是css方法.一个页面由html.css.js组成,按照浏览器解析机制 ... 
