Loading collection data...
Collections are a way for you to organize kata so that you can create your own training routines. Every collection you create is public and automatically sharable with other warriors. After you have added a few kata to a collection you and others can train on the kata contained within the collection.
Get started now by creating a new collection.
for recursion, it's important to define the terminating condition
if (p0>= p) return 0
.Note that
0
is an identity value for addition (1 + 0 =1
).It's also important to consider using
tail recursion
to avoidStackOverflowError
i.e.
1 + nbYear
instead ofnbYear + 1
that way compiler can optimize calls
e.g (1 + (1 + nbYear)) -> 2 + nbYear
instead of (nbYear + (nbYear + 1))
For some reason that I don't know, using MAX_VALUE give better performance than using index 0
"==" is valid if you're comparing two primitive types of data, like Integers, booleans and so. Otherwise, you use .equals(), that is a default method from every object to compare objects (In this case, any instance of 'String' is an object so you must use .equals() to compare two Strings).
yep, no need to use MAX_VALUE, as you always can set init value similar to index 0 element in array
the kata code has since been changed, so this deletion will now break this solution
@Lomuss33 please always use a spoiler flag when discussing code / methods. I have added the tag to your comment.
This comment is hidden because it contains spoiler information about the solution
ik its been 7 months but I'll answer for anyone new here. .equals() is used to compare two Strings. == is for numbers.
This comment is hidden because it contains spoiler information about the solution
That is absolutely idiotic. The task, I mean. The solution is genius though.
Unfortunately, this is not tail-recursive. All of the intermediate calls need to be kept on the stack because they still have work to do, specifically: adding 2 to the result of the recursive call they are waiting on.
Shit looks so messi.
Nice solution
Yup, i got the same idea. But im not familiar w Java syntax. I'll keep practicing.
You can initialize month as 0 and move "month++" to the beginning of the loop. This way you don't need the "--month" in the return.
Loading more items...