因此,正如标题所希望的那样,这是上述书中的一个例子。
我对编程还是个新手,调试也有困难。尽管如此,任何批评都是受欢迎的,特别是如果它显示出一种更有效的编码方式;请记住,我仍然是新的,所以如果你给我一个新的内置函数或其他东西,我可能不知道你指的是什么。
所以这个练习的重点是写一个函数,给它三个参数,来确定这三个参数是否构成一个三角形。这是我的代码:
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
我猜是两行的总和,但我不知道它出了什么问题。有人能帮我调试一下吗?
我花了一个小时的时间用内置的函数重写它(以各种方式,到处都是一堆
or
s)。但看起来很糟糕,我宁愿学着用这种方式写作。 最佳答案
问题在于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/