0
How these recursion works?
Hey can anyone explain to me how these recursion works? and what is the solution? i really have no idea thank a lot def charge= (h,k): z = 0 outcome= 0 while z < h: for i in range (z, k+1, 1): if i < 1: outcome = k elif i < 4: outcome = outcome + i else: outcome = outcome + h z = z + 2 return outcome print charge(5,5)
10 odpowiedzi
0
Sal
Because of the last expression in the while loop:
z = z + 2
starting from z=0 (initialized before the while loop)
running for z<h, where h=5 from the function call
so when 6<5 it is false and it does not run anymore
+ 1
check this post.
https://www.sololearn.com/discuss/1149517/?ref=app
+ 1
Matthias
many thanks:)
+ 1
Matthias
aah now i get it. thank you:)
0
This is not a recursion, since the function does not call itself.
I don't really know if this has some real world source, but let's see how to get the value;
z=0
range(0,6,1)
i outcome
0 5
1 6
2 8
3 11
4 16
5 21
z=2
range(2,6,1)
i outcome
2 23
3 26
4 31
5 36
z=4
range(4,6,1)
i outcome
4 41
5 46
z=6
while loop terminated
So it prints 46.
0
hey Matthias,
many thanks. now i understand.
but can you explain how the otcome for z=0; i=4 is 16 ?
And the outcome for z=2; i=5 is 26?
thank you;)
0
Sal
If i equals 4 or is greater than 4, you will get in the else branch.
And there you add +h to your outcome.
Here we have h=5, from the call charge(5,5)
The other was a typo, it should be 36
0
Matthias
hello,
i have a last question. how did you know that you have to repeat z for 0, 2 ,4 to 6?
0
Glad to help :)
0
Matthias
i have a last question. really last question^^
def function (k):
if k<2:
return k
else:
return function(k-1)+function(k-2)
n=8
z=function(n)
print str (z)
solution for this function:
8-1 + 8-2 = 13
7-1 + 5-2 = 9
6-1 + 3-2 = 6
so outcome is: 28
am i right?