国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python查找第k小元素代碼分享

2020-02-23 05:01:34
字體:
供稿:網(wǎng)友

代碼如下:
# -*- coding: utf-8 -*-

from random import randint
from math import ceil, floor

def _partition(A, l, r, i):
    """以A[i]為主元劃分?jǐn)?shù)組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 # 索引標(biāo)記
    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小的數(shù),k in [l+1,r+1]:

    其尾遞歸方式,偽碼如下:
    SELECT(A, l, r, k)
    1  while true:
    2    i ← ? // 劃分主元位置
    3    m ← PARTITION(A, l, r, i) // 數(shù)組劃分
    4    n ← m - l + 1 // A[l..m]元素個數(shù)
    5    if k = n // 檢查A[m]是否是第k小的元素
    6      then return A[m]
    7    elseif k < n // 左劃分區(qū)
    8      r = m - 1
    9    else // 右劃分區(qū)
    10     k = k - n
    11     l = m + 1

    Args:
        pivot_selector(Function): 主元選取方法,默認(rèn)隨機方式
    """
    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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 巴塘县| 广灵县| 高唐县| 温泉县| 十堰市| 黄龙县| 奇台县| 即墨市| 东平县| 灌南县| 瓦房店市| 彭泽县| 叙永县| 远安县| 漯河市| 巴彦淖尔市| 扶绥县| 鹤岗市| 西昌市| 赤水市| 肇东市| 大英县| 革吉县| 延寿县| 隆回县| 仁寿县| 华蓥市| 叙永县| 高密市| 新乡县| 郯城县| 永嘉县| 疏附县| 巧家县| 湘潭市| 台中县| 博爱县| 徐闻县| 府谷县| 大理市| 安康市|