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 trialVishal Vikram
251 PointsYour task is to construct a building which will be a pile of n cubes. The cube at the bottom will have a volume of n^3,
Your task is to construct a building which will be a pile of n cubes. The cube at the bottom will have a volume of n^3, the cube above will have volume of (n-1)^3 and so on until the top which will have a volume of 1^3.
You are given the total volume m of the building. Being given m can you find the number n of cubes you will have to build?
The parameter of the function findNb (find_nb, find-nb) will be an integer m and you have to return the integer n such as n^3 + (n-1)^3 + ... + 1^3 = m if such a n exists or -1 if there is no such n.
1 Answer
James J. McCombie
Python Web Development Techdegree Graduate 21,199 PointsHello,
Not entirely sure why you have posted this, for help?, stuck on a challenge?
well this will get the result you want...
def findNB(m):
if 1 ** 3 == m:
return 1
else:
n = 2
volume = 1
while volume < m:
volume = volume + n ** 3
if volume == m:
return n
else:
n = n + 1
continue
return -1
could probably make this more elegant, perhaps solve recursively, but that's just a quick stab at it, if you could give a little more information around what you want from this question, perhaps I can assist better. I have tested this function, it works fine.