子洋丶 2019-05-09 22:28 采纳率: 100%
浏览 531
已采纳

python pop删除列表报错

我照着《算法图解》中选择排序的代码敲了一遍,

运行时却提示报错,错误码如下:

UnboundLocalError: local variable 'samllest_index' referenced before assignment

代码如下

def findSmallest (arr):
    smallest = arr[0]
    smallest_index = 0
    for i in range(1,len(arr)):
        if arr[i] < smallest:
            samllest = arr[i]
            samllest_index = i

    return samllest_index


def selectionSort(arr):
    newArr = []
    for i in range(len(arr)):
        smallest = findSmallest(arr)
        newArr.append(arr.pop(smallest))

    return newArr

array = [5,3,6,2,10]
print("数组最小值的下标是:{}".format(findSmallest(array)))
print (selectionSort(array))

查了好久,不知道问题所在,求解!!!

  • 写回答

1条回答 默认 最新

  • waple_0820 博客专家认证 2019-05-11 15:39
    关注

    6, 7, 9行 smallest 不是 samllest

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?