Why sort() in Javascript not sorting... 🤔

·

2 min read

Although I have being using Javascript for a while now but never solved a leetocode problem using it so I tried solving a basic problem using Javascript, and tried to play around. What I found was very "weird"...

So I was trying to sort an array of number using .sort() method and i used below code to sort:

const myArray = myArray.sort();

then I console.log()ed it to see the result, and it was sorted in ascending order. But when I tried to sort it in descending order, it didn’t work. I tried to do this:

const myArray = myArray.sort().reverse();

even this didn’t work. Which prompted me to look into the documentation of the sort function. And to my absolute surprise, I saw this example on mdn docs:

const months = ["March", "Jan", "Feb", "Dec"];
months.sort();
console.log(months);
// expected output: Array ["Dec", "Feb", "Jan", "March"]

const array1 = [1, 30, 4, 21, 100000];
array1.sort();
console.log(array1);
// expected output: Array [1, 100000, 21, 30, 4]

The first example made sense, but the second one was SHOCKING, and then I read this in the documentation of the sort function:

🙃
The default sort order is built upon converting the elements into strings, then comparing their sequences of UTF-16 code units values.

So, the sort function converts the elements into strings, and then compares them. Therefore, when I tried to sort an array of numbers, it converted them into strings, and then compared them. Which just doesn’t work for numbers, because the string representation of 100000 is greater than the string representation of 21, which is greater than the string representation of 4, and so on.

This is a very weird behaviour. I don’t know why they did this, but I think they should have made a separate function for sorting strings, and kept the sort function for sorting numbers. Or they should have made the sort function work for both numbers and strings.

I hope someone finds this useful.

Also in js to sort an array of numbers in descending order, you can do this:

const myArray = myArray.sort((a, b) => b - a);

ok bye now....

Â