如何像计算机科学家一样思考

如何像计算机科学家一样思考

因此,正如标题所希望的那样,这是上述书中的一个例子。
我对编程还是个新手,调试也有困难。尽管如此,任何批评都是受欢迎的,特别是如果它显示出一种更有效的编码方式;请记住,我仍然是新的,所以如果你给我一个新的内置函数或其他东西,我可能不知道你指的是什么。
所以这个练习的重点是写一个函数,给它三个参数,来确定这三个参数是否构成一个三角形。这是我的代码:

def is_triangle(a,b,c):
    num_list = [a,b,c]
    biggest = max(num_list)
    other_two = num_list.remove(biggest)
    sum_of_two = sum(other_two)

    if sum_of_two > biggest:
        print 'Congrats, %d, %d, and %d form a triangle!' % (a,b,c)
    elif sum_of_two == biggest:
        print 'That forms a degenerate triangle!'
    else:
        print 'That does\'t make any sort triangle... >:['


def sides():
    side1 = raw_input('Please input side numero Juan: ')
    side2 = raw_input('Now side two: ')
    side3 = raw_input('...aaaannnd three: ')
    import time
    time.sleep(1)
    print 'Thanks >:]'
    side1 = int(side1)
    side2 = int(side2)
    side3 = int(side3)
    is_triangle(side1,side2,side3)

sides()

但是,无论何时运行它,我都会得到以下信息:
Traceback (most recent call last):
  File "A:/Python/is_triangle.py", line 27, in <module>
    sides()
  File "A:/Python/is_triangle.py", line 25, in sides
    is_triangle(side1,side2,side3)
  File "A:/Python/is_triangle.py", line 5, in is_triangle
    sum_of_two = sum(other_two)
TypeError: 'NoneType' object is not iterable

我猜是两行的总和,但我不知道它出了什么问题。有人能帮我调试一下吗?
我花了一个小时的时间用内置的函数重写它(以各种方式,到处都是一堆ors)。但看起来很糟糕,我宁愿学着用这种方式写作。

最佳答案

问题在于remove修改了基础列表-它不会返回新列表。更改为:

num_list.remove(biggest)
sum_of_two = sum(num_list)

要了解发生这种情况的确切原因,请在空闲时尝试以下操作:
>>> x = [1,2,3,4,5]
>>> x.remove(1)
>>> x
[2,3,4,5]

关于python - 如何像计算机科学家一样思考,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16784041/

10-11 18:27