python算法——第四天
递归
def func(num):
if num / 2 > 0:
num -= 1
print(num)
num = func(num)
print('quit')
return num func(10)
二分查找
def binary_search(data_list,find_num):
mid_pos = int(len(data_list) / 2) # 计算需要查找数据的长度的一半
mid_val = data_list[mid_pos] # 获取中间位置的那个值
print(data_list) # 查看每次剩余筛选的数据列表
if len(data_list) > 0: # 当列表长度大于0时,则一直查找
if mid_val > find_num: # 如果中间的数比实际要查找的数大,那么这个数肯定在左边
print("%s should be in left of [%s]" % (find_num, mid_val))
binary_search(data_list[:mid_pos], find_num)
elif mid_val < find_num: # 如果中间的数比实际查找的数小,那么这个数肯定在右边
print("%s should be in right of [%s]" % (find_num, mid_val))
binary_search(data_list[mid_pos:], find_num)
else: # 如果中间数与实际查找的数恰巧相等,那么这个数肯定是要找的拿个数
print("Find %s" % find_num) else: # 否则就是买药这个数
print("cannot find [%s] in data_list" % find_num) if __name__ == '__main__':
primes = [1, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97]
binary_search(primes, 1) # 在列表里面查找1
二分查找二
def binary_search(array, target):
"""
二分查找
前提是数组排序好的
先把中间值找出来
当中间元素大于查找的目标元素,则将左边的索引位置移动到中间位置的下一个位置
当中间元素小于查找的目标元素,则将右边的索引位置移动到中间位置的上一个位置
当中间元素等于查找的目标元素,则停止查找,返回目标元素位置
:param array:
:param target:
:return:
"""
left = 0
right = len(array) - 1
while left <= right:
mid_position = (left + right) // 2
if array[mid_position] == target:
return mid_position
elif target < array[mid_position]:
right = mid_position - 1
else:
left = mid_position + 1
return -1
多维数组交叉
array = [[col for col in range(4)] for row in range(4)] # 初始化一个4*4数组
# array=[[col for col in 'abcd'] for row in range(4)] for row in array: # 旋转前先看看数组长啥样
print(row) for i, row in enumerate(array): for index in range(i, len(row)):
tmp = array[index][i] # 将每一列数据在每一次遍历前,临时存储
array[index][i] = array[i][index] # 将每一次遍历行的值,赋值给交叉的列
print(tmp, array[i][index]) # = tmp
array[i][index] = tmp # 将之前保存的交叉列的值,赋值给交叉行的对应值
for r in array: # 打印每次交换后的值
print(r)
冒泡排序
def bubble_sort(array):
"""
每次将后面的元素大于前面的元素交换位置
:param array:
:return:
"""
for i in range(len(array)):
for j in range(i + 1, len(array)):
if array[i] > array[j]:
array[i], array[j] = array[j], array[i]
插入排序
def insert_sort(array):
"""
找出最小位置,然后替换
:param array:
:return:
"""
for i in range(len(array)):
key = array[i]
j = i - 1
while j >= 0 and array[j] > key:
array[j + 1] = array[j]
j -= 1
array[j + 1] = key
选择排序
def select_sort(array):
"""
选则一个最小的位置,然后交换两个元素的位置
:param array:
:return:
"""
for i in range(len(array) - 1):
min_index = i
for j in range(i + 1, len(array)):
if array[j] < array[min_index]:
min_index = j
array[i], array[min_index] = array[min_index], array[i]
快速排序
def quick_sort(array):
"""
将一个数组分割为三份,一个为基数,一个是比基数大的列表,一个是比基数小的列表
然后再将比基数小的列表按照上面方式再分三份,直到分到不能再分位置
同样,也将比基数大的列表按上述分三份,直到不能再分为止
最后合并得到一个排序好的列表
:param array:
:return:
"""
if len(array) < 2:
return array
first_element = array[0]
left = [i for i in array[1:] if i <= first_element]
right = [i for i in array[1:] if i > first_element]
return quick_sort(left) + [first_element] + quick_sort(right)
快速排序二
def partition(array, p, r):
x = array[r]
i = p - 1
for j in range(p, r):
if array[j] <= x:
i = i + 1
array[i], array[j] = array[j], array[i]
array[i + 1], array[r] = array[r], array[i + 1]
return i + 1 def quick_sort2(array, p, r):
if p < r:
q = partition(array, p, r)
quick_sort2(array, p, q - 1)
quick_sort2(array, q + 1, r)
斐波那契数列
def fibonacci(n):
a, b = 0, 1
while n > 0:
yield b
a, b = b, a + b
n -= 1
阶乘
def factorial(n):
"""
阶乘
1 * 2 * ... * n
直到n为1,则返回,然后合并相乘
:param n:
:return:
"""
# return n * factorial(n - 1) if n != 1 else n
result = 1
for i in range(1, n + 1):
result *= i
return result
线性搜索
def line_search(array, target):
"""
线性查找
按照数组顺序,依次查找目标元素
:param array:
:param target:
:return:
"""
position = 0
while position < len(array):
if array[position] == target:
return position
position += 1
return -1
python算法——第四天的更多相关文章
- python算法题 python123网站单元四题目
目录 一:二分法求平方根 二:Collatz猜想 三:算24(只考虑满足,不考虑把所有情况找出来) 下面向大家介绍几个python算法题. 一:二分法求平方根 1.题目要求为 2.输入输出格式为 ...
- python算法(一)
python算法(一) 一.求数x的因子 x=100 divisors=()#初始化空的元组 for i in range(1,x): if x%i==0: divisors=divisors+(i, ...
- 安装Python算法库
安装Python算法库 主要包括用NumPy和SciPy来处理数据,用Matplotlib来实现数据可视化.为了适应处理大规模数据的需求,python在此基础上开发了Scikit-Learn机器学习算 ...
- 数据结构与算法JavaScript (四) 串(BF)
串是由零个或多个字符组成的有限序列,又叫做字符串 串的逻辑结构和线性表很相似的,不同的是串针对是是字符集,所以在操作上与线性表还是有很大区别的.线性表更关注的是单个元素的操作CURD,串则是关注查找子 ...
- 算法第四版 在Eclipse中调用Algs4库
首先下载Eclipse,我选择的是Eclipse IDE for Java Developers64位版本,下载下来之后解压缩到喜欢的位置然后双击Eclipse.exe启动 然后开始新建项目,File ...
- Python 基础语法(四)
Python 基础语法(四) --------------------------------------------接 Python 基础语法(三)------------------------- ...
- 初学 Python(十四)——生成器
初学 Python(十四)--生成器 初学 Python,主要整理一些学习到的知识点,这次是生成器. # -*- coding:utf-8 -*- ''''' 生成式的作用: 减少内存占有,不用一次性 ...
- Python第二十四天 binascii模块
Python第二十四天 binascii模块 binascii用来进行进制和字符串之间的转换 import binascii s = 'abcde' h = binascii.b2a_hex(s) # ...
- java排序算法(四):冒泡排序
java排序算法(四):冒泡排序 冒泡排序是计算机的一种排序方法,它的时间复杂度是o(n^2),虽然不及堆排序.快速排序o(nlogn,底数为2).但是有两个优点 1.编程复杂度很低.很容易写出代码 ...
随机推荐
- Win10 UAP 绑定
Compiled DataBinding in Windows Universal Applications (UAP) http://nicksnettravels.builttoroam.com/ ...
- java大数取模
题目链接:http://lightoj.com/volume_showproblem.php?problem=1214 用java写大数果然是方便多了! import java.math.BigInt ...
- 数字信号处理实验(一)——DTFT
1.MATLAB自编绘图函数 function [] = signal_write(X,w,flag) % X:数据 % w:频率向量 magX=abs(X);angX=angle(X); realX ...
- 【spring bean】spring中bean的懒加载和depends-on属性设置
项目结构如下: ResourceBean.java代码: package com.it.res; import java.io.File; import java.io.FileNotFoundExc ...
- maven会报Could not transfer artifact xxx错误
需要在你的eclipse更新一下maven的包 如下:
- Maven项目在Eclipse中调试 Debug
废话不说一路跟图走. 断点会进入到如下页面点击Edit Source Lookup Path 如下图操作 成功进入Debug模式
- try : finally语句
try:finally语句不管有没有异常他都会执行:他就是用来清理的try: h=open("ll","r") y=h.read() print (int(y) ...
- 记一次小团队Git实践(中)
对于初学者,从使用上先入手,往往学的最快,并从中汲取教训,再回头更深入的学习,效果尤佳. 安装git 安装git自不必说,mac已经内置了git,linux下一个命令就能搞定,windows下需要下载 ...
- 后缀数组 POJ 1743 Musical Theme
题目链接 题意:给定n个数字,求超过5个数字的,最长的,变化相同的,不相交的重复子串 分析:男人8题中的一题!数列相邻两项做差,形成新数列,即求数列中的最长重复子串(不可相交). 后缀数组+二分答案. ...
- JSP通过IP获取用户(客户端)的地理位置信息
<%!//获取客户端的IP public String getRemoteIP(HttpServletRequest request) { if (request.getHeader(" ...