python - i阶统计python的确定性快速选择(中位数方法的中位数)

标签 python algorithm error-handling quicksort implementation

dselect 在 O(n) 时间内找到给定的未排序整数列表(无重复项)中的第 i 个顺序统计信息,搭载快速排序的原则。第 i 个顺序统计量定义为给定列表中已排序版本中的第 i 个最小元素。所以一阶统计量将是最小的元素,n 阶统计量将是最大的元素等等...

在运行时,我在 dselect 函数末尾的 return arr[l] 上得到了 IndexError: list index out of range。我认为错误的产生是由于我在 dselect< 上的列表 medians 的递归调用中将 l 硬编码为 0/功能。 (第 4 行)

我应该怎么做才能避免这个错误?我应该如何将 l 的值放入该递归调用中?这甚至是这个错误的根源吗?如果这是一个愚蠢的问题,请随时指出,我会删除这个问题。我不得不问这个,因为我已经坚持了很长一段时间了。谢谢。

def dselect(arr, l, r, i):
    if l < r:
        #finding pivot deterministically
        medians = createMedianList(arr, l, r)
        pivot = dselect(medians, 0, len(medians) - 1, len(medians) // 2) #line4

        pivot = partition(arr, l, r, pivot)
        if pivot + 1 == i:
            return arr[pivot]
        elif pivot + 1 > i:
            return dselect(arr, l, pivot - 1, i)
        else:
            return dselect(arr, pivot + 1, r, i)

    return arr[l]

def partition(arr, l, r, pivot):
    pivotIndex, i = arr.index(pivot), l
    arr[l], arr[pivotIndex] = arr[pivotIndex], arr[l]

    for j in range(l + 1, r + 1):
        if arr[j] < arr[l]:
            i += 1
            arr[i], arr[j] = arr[j], arr[i]
    arr[l], arr[i] = arr[i], arr[l]

    return i

def createMedianList(arr, l, r):
    medians = []
    for i in range(l, (r + 1) - 5 + 1):
        temp = sorted(arr[i:i + min(5, (r - l + 1) - i)])
        medians.append(temp[len(temp) // 2])

    return medians

if __name__ == '__main__':
    arr = [5, 2, 4, 3, 1, -1]
    #arr = list(map(int, open('select.txt').read().splitlines()))
    print(dselect(arr, 0, len(arr) - 1, int(input('Which order 
    statistic to find? '))))

最佳答案

问题是 createMedianList 有时会返回一个空列表: 如果 l >= r-3 最终会发生这种情况。 我建议您向 createMedianList 添加一些内容,以确保它不会返回空列表。 例如:if medians==[]:medians=[arr[0]] 或类似的东西(取决于您希望中位数具有哪些属性)。

关于python - i阶统计python的确定性快速选择(中位数方法的中位数),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45798841/

相关文章:

python - 如何从 Python 中的 TreeView 获取实际的行对象

python - 在 RPi 3 上复制文件的奇怪脚本行为

Python 正则表达式排除下划线

arrays - 计算 DAG 中所有长度的路径数

javascript - 处理axios错误和响应(vue)仅适用于一个错误。如何通知多个错误?

python - Websockets,异步处理用户输入。获取连接关闭错误 1006

python - 以相同的方式、算法或数学方程从列表中获取元素

c++ - 特殊的简单随机数发生器

python - 函数在错误处理中调用自身是Pythonic吗?

PHP ErrorFlag 检查?