Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialTiago Ramos
2,380 PointsWhere's my mistake?
Hey guys I think I've done all the logic of the task. I can't understand where did I go wrong. Any ideas? Thank you :)
import random
start = 5
while start is True:
num = random.randint(1, 99)
def even_odd(num):
# If % 2 is 0, the number is even.
# Since 0 is falsey, we have to invert it with not.
return not num % 2
if even_odd(num) == True:
print("{} is even".format(num))
else:
print("{} is odd".format(num))
start = start - 1
1 Answer
Stuart Wright
41,120 PointsYou just need to change:
while start is True:
to simply:
while start:
Your variable 'start' is equal to 5 at the start of the program, which is a 'truthy' value, but when you compare it to True using 'is', that evaluates to False.
As a side note, it would be best to have the even_odd() function definition outside the loop so that it isn't redefined every time, but the way you've done it still works.
Here's how my full solution would look:
import random
def even_odd(num):
# If % 2 is 0, the number is even.
# Since 0 is falsey, we have to invert it with not.
return not num % 2
start = 5
while start:
num = random.randint(1, 99)
if even_odd(num):
print("{} is even".format(num))
else:
print("{} is odd".format(num))
start -= 1
Tiago Ramos
2,380 PointsTiago Ramos
2,380 PointsHi Stuart, thanks a lot :) I simply changed the "while start:" and it worked really well ;) Cheers