子洋丶 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

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

报告相同问题?

悬赏问题

  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
  • ¥15 安装svn网络有问题怎么办