python第k序列元素查找_python查找第k小元素代码分享 -电脑资料
复制代码代码如下:
# -*- coding: utf-8 -*-
from random import randint
from math import ceil, floor
def _partition(A, l, r, i):
"""以A[i]为主元划分数组A[l..r],使得:
A[l..m-1] <= A[m] < A[m+1..r]
"""
A[i], A[r] = A[r], A[i] # i交换到末位r,作为主元
pivot = A[r] # 主元
m = l # 索引标记
for n in xrange(l, r): # l..r-1
if A[n] <= pivot:
A[m], A[n] = A[n], A[m] # 交换
m += 1 # 后移
A[m], A[r] = A[r], A[m] # 主元到m位
return m
def _rand(A, l, r):
"""随机划分主元"""
return randint(l, r) # A[l..r]随机取一个
def _select(A, l, r, k, pivot_selector = _rand):
"""利用快排,得A[l..r]中第k小的数,k in [l+1,r+1]:
其尾递归方式,伪码如下:
SELECT(A, l, r, k)
1 while true:
2 i ← ? // 划分主元位置
3 m ← PARTITION(A, l, r, i) // 数组划分
4 n ← m - l + 1 // A[l..m]元素个数
5 if k = n // 检查A[m]是否是第k小的元素
6 then return A[m]
7 elseif k < n // 左划分区
8 r = m - 1
9 else // 右划分区
10 k = k - n
11 l = m + 1
Args:
pivot_selector(Function): 主元选取方法,默认随机方式
"""
if not A:
return None
if l == r:
return A[l]
while True:
i = pivot_selector(A, l, r)
m = _partition(A, l, r, i)
n = m - l + 1
if k == n:
return A[m]
elif k < n:
r = m - 1
else:
k = k - n
l = m + 1
def rand_select(A, k):
"""默认随机划分主元方式,k in [1, len(A)]
E[T(n)] = O(n)
"""
return _select(A, 0, len(A) - 1, k);
def _median(A, l, r):
"""对A[l..r]插入排序(原地)后选取其中位数位置"""
for j in xrange(l, r + 1):
k = A[j]
i = j
while i > l and A[i-1] > k:
A[i] = A[i-1]
i -= 1
A[i] = k
return l + int((r - l) * 0.5) # 下中位数
def _medianOfMedians(A, l, r):
"""中位数的中位数方式:
1. 划分为floor(n/5)个5元组,剩下(n%5)组成最后一组,
2. 找出ceil(n/5)个组各自的中位数。先对每组插入排序,再从中选出中位数。
3. 对第2步中找出的ceil(n/5)个中位数重复上述操作,直到仅有一个中位数。
"""
if l == r:
return l
n = r - l + 1 # 元素个数
m = int(ceil(n / 5.0)) # 划分组数,每组5个元素
for i in xrange(m):
# 每组起始位和结束位
sub_l = l + i * 5
sub_r = sub_l + 4
if sub_r > r:
sub_r = r
# 对每组元素插入排序后,选取中位数
sub_m = _median(A, sub_l, sub_r) # 中位数索引
# 交换中位数到前几位
j = l + i
A[j], A[sub_m] = A[sub_m], A[j]
return _medianOfMedians(A, l, l + m - 1) # 中位数的中位数
def bfprt_select(A, k):
"""中位数的中位数方式(BFPRT算法)
T(n) = O(n)
"""
return _select(A, 0, len(A) - 1, k, _medianOfMedians);
def _median3(A, l, r):
"""三数中位数方式,取l,r,(l+r)/2三数中位数"""
c = (l + r) / 2
keys = [l, c, r]
i = _median(keys, 0, 2)
return keys[i]
def median_select(A, k):
"""三数中位数方式,以消除最坏情况"""
return _select(A, 0, len(A) - 1, k, _median3);
if __name__ == '__main__':
import random, time
from copy import copy
print('preparing data...')
n = 1000000
nums = range(n)
random.shuffle(nums)
print('ready go!')
def timeit(fnc, *args, **kargs):
print('%s starts processing' % fnc.__name__)
begtime = time.clock()
retval = fnc(*args, **kargs)
endtime = time.clock()
print('%s takes time : %f' % (fnc.__name__, endtime - begtime))
return retval
test_methods = [rand_select, bfprt_select, median_select]
k = random.randrange(n) + 1
dashes = '---' * 10
for test in test_methods:
print(dashes)
nums_new = copy(nums)
result = timeit(test, nums_new, k)
print('the %dth smallest element: %d' % (k, result))
QQ空间 搜狐微博 人人网 开心网 百度搜藏更多
Tags:python 第k小元素
复制链接收藏本文打印本文关闭本文返回首页
上一篇:python获取beautifulphoto随机某图片代码实例
下一篇:windows下wxPython开发环境安装与配置方法
相关文章
2014-02-02python求斐波那契数列示例分享
2012-10-10python笔记(1) 关于我们应不应该继续学习python
2009-03-03Python字符串的encode与decode研究心得乱码问题解决方法
2014-02-02Python的print用法示例
2012-08-08Python运行的17个时新手常见错误小结
2014-02-02使用python在校内发人人网状态(人人网看状态)
2014-05-05使用python实现拉钩网上的FizzBuzzWhizz问题示例
2013-11-11python解析json实例方法
2014-01-01python使用 api上传图片到微博示例
2006-10-10学习python (2)
文章评论
最 近 更 新
Python 第一步 hello world
一篇不错的Python入门教程
python根据经纬度计算距离示例
Python中使用中文的方法
Python操作Mysql实例代码教程在线版(查询
python的id()函数介绍
浅析python 内置字符串处理函数的使用方法
python3使用tkinter实现ui界面简单实例
python的几种开发工具介绍
Python 调用DLL操作抄表机
热 点 排 行
Python入门教程 超详细1小时学会
python 中文乱码问题深入分析
比较详细Python正则表达式操作指
Python字符串的encode与decode研
Python open读写文件实现脚本
Python enumerate遍历数组示例应
Python 深入理解yield
Python+Django在windows下的开发
python 文件和路径操作函数小结
python 字符串split的用法分享
python第k序列元素查找_python查找第k小元素代码分享 -电脑资料相关推荐
- python第k序列元素查找_Python寻找第k小的元素
更多: http://my.oschina.net/u/438371/blog/131956 1.[代码][Python]代码 # -*- coding: utf-8 -*- from random ...
- python类似图片查找_python查找重复图片并删除(图片去重)
本文实例为大家分享了python查找重复图片并删除的具体代码,供大家参考,具体内容如下 和网络爬虫配套的,也可单独使用,从网上爬下来的图片重复太多,代码支持识别不同尺寸大小一致的图片,并把重复的图片删 ...
- python 中文查找_python 查找数据库
django.db.utils.ProgrammingError: 1146 的解决办法 在models中设置完数据库相关的东西后执行命令 python manage.py makemigration ...
- python求一个序列的和_Python合集之Python序列(三)
在上一节的合集中,我们了解了Python 序列的相加及相乘的相关知识,本节我们将进一步了解一下Python序列的长度 最大最小值及元素的检查等相关知识. 1.检查某个元素是否是序列的成员 在Pytho ...
- python快递分拣小程序_python英语单词测试小程序代码实例
这篇文章主要简介了python英语单词测试小程序代码实例,文中通过示例代码简介的非常具体,对大家的学习或者工作具有一定的参考学习网上卖,需要的朋友可以学习下 爬取了扇贝英语网,并制作了一个英语单词测试 ...
- python numpy 生成矩阵_Python numpy生成矩阵、串联矩阵代码分享
import numpy 生成numpy矩阵的几个相关函数: numpy.array() numpy.zeros() numpy.ones() numpy.eye() 串联生成numpy矩阵的几个相关 ...
- python贪吃蛇程序_Python 实现 贪吃蛇大作战 代码分享
感觉游戏审核新政实施后,国内手游市场略冷清,是不是各家的新游戏都在排队等审核.媒体们除了之前竞相追捧<Pokemon Go>热闹了一把,似乎也听不到什么声音了.直到最近几天,突然听见好几人 ...
- python画球轨迹图_python绘制铅球的运行轨迹代码分享
我们按照面向过程程序设计的思想,使用python编写了程序,追踪铅球在运行过程中的位置信息.下面,修改程序代码,导入turtle模块,将铅球的运行轨迹绘制出来. python3代码如下: from m ...
- python测试代码_python英语单词测试小程序代码实例
这篇文章主要介绍了python英语单词测试小程序代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 爬取了扇贝英语网,并制作了一个英语单词测试的 ...
最新文章
- 算法学习之路|称量硬币(模拟)
- USTC English Club Note20211110
- java查找最小字符集_如何查找Java中的默认字符集/编码?
- 每日程序C语言20-利用递归求阶乘
- Codeforces Round #694 (Div. 2) E. Strange Shuffle 交互 + 思维分块
- CoderHub接口文档
- zz:NETCONF协议详解
- linux sh 脚本调用外部命令
- size_t,__T,_T,TEXT,_TEXT等一些特殊宏的理解
- 中国移动锁定数据业务新战略
- GIS理论(墨卡托投影、地理坐标系、地面分辨率、地图比例尺、Bing Maps Tile System)转载...
- java面向对象相关选择题_java面向对象练习题一
- 通过CSS3 Media Query实现响应式Web设计
- 洛谷P2024 [NOI2001]食物链
- godaddy 域名 绑定阿里云服务器 绑定tomcat (.fm的域名可以看看)
- 基于PLC的实验室设备远程监控方案
- python生成一维数组,二维数组
- Jenkins官方社区携手灵雀云成功举办Jenkins Meetup
- MS Access 教程之 如何解决从 Access 复制到 Excel 太慢问题?
- 5. 第五阶段 测试开发技术 - JAVA