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.
This solution is elegant, but has poor performance due to the fact that the sum of the digits of a single number can be calculated more than once in the sort() function.
So the complexity is O(m⋅logm⋅k), where
"m" is the number of numbers,
"k" is the average length of the number.
My solution calculates the weights once, so its complexity is O(m⋅k+m⋅logm).
On the other hand, if we assume that "k" is 2, that is, a constant (hardly anyone weighs more than 999), then the complexity in this and in my case becomes equal to O(m⋅logm). In addition, my solution consumes more memory. So decide for yourself what you like best.
sum
is not an array, but a function. Because it's called twice on each comparison during sorting, you may end up with some numbers having their sum calculated multiple times.Why? As I understand it, the sums for each number are only calculated once. During the compare the sum array is only referenced.
What is sumA === sumB ? Does it means each signle string number equal ?
It is indeficent, it will do the sum several times per each number
I don't like using both declarations and expressions for functions.
The callback you pass into reduce can do everything, including parseInt
oooohhhh very nice. I feel terrible now hahahaha
Love it!
I know it's a while now, but for whoever is also wondering:
I believe it's just a matter of preference using
const
arrow-functions for one-liners andfunction
for longer functions.Never knew that reduce works as a int parser, could be one line less for me :-)
Nice one
Wow, talk about leveraging functional programming to the fullest!
Very impressed/confused. Thank you all for the valuable lesson.
Why have sum be a const and then comp be a function? Couldn't they both be constants?