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 trialrob bert
5,041 PointsFailing test with code that appears to work.
So the fourth function appears to be working, but i'm not passing the test. if i call: print(reverse_evens([1, 2, 3, 4, 5])) i get [5, 3, 1] which appears to be correct.
def first_4(list1):
out = list1[:4]
return out
def first_and_last_4(list1):
out = list1[:4] + list1[-4:]
return out
def odds(list1):
out = list1[1::2]
return out
def reverse_evens(list1):
out = list1[::-2]
return out
1 Answer
Steven Parker
231,248 PointsYou're half right. Your method will work when the list has an odd number of items. But when the list has an even number of items, it will return reverse odds instead.
To always return reverse evens, there's two basic strategies:
- compute the starting position based on the list size
- extract the even index values first, then reverse them
Either one will pass the challenge when implemented correctly.