# Tutorial

## Sorting an Array

The `sort()` method sorts an array alphabetically:

## Reversing an Array

The `reverse()` method reverses the elements in an array.

You can use it to sort an array in descending order:

## Numeric Sort

By default, the `sort()` function sorts values as strings.

This works well for strings ("Apple" comes before "Banana").

However, if numbers are sorted as strings, "25" is bigger than "100", because "2" is bigger than "1".

Because of this, the `sort()` method will produce incorrect result when sorting numbers.

You can fix this by providing a compare function:

const points = ;
points.sort(function(a, b){return a - b});

Use the same trick, same as above example but this is for array descending:

## The Compare Function

The purpose of the compare function is to define an alternative sort order.

The compare function should return a negative, zero, or positive value, depending on the arguments:

function(a, b){return a - b}

When the `sort()` function compares two values, it sends the values to the compare function, and sorts the values according to the returned (negative, zero, positive) value.

If the result is negative `a` is sorted before `b`.

If the result is positive `b` is sorted before `a`.

If the result is 0 no changes are done with the sort order of the two values.

Example:

The compare function compares all the values in the array, two values at a time `(a, b)`.

When comparing 40 and 100, the `sort()` method calls the compare function(40, 100).

The function calculates 40 - 100 `(a - b)`, and since the result is negative (-60),  the sort function will sort 40 as a value lower than 100.

You can use this code snippet to experiment with numerically and alphabetically sorting:

## The Fisher Yates Method

The above example, array.sort(), is not accurate, it will favor some numbers over the others.

The most popular correct method, is called the Fisher Yates shuffle, and was introduced in data science as early as 1938!

In JavaScript the method can be translated to this:

## Find the Highest (or Lowest) Array Value

There are no built-in functions for finding the max or min value in an array.

However, after you have sorted an array, you can use the index to obtain the highest and lowest values.

Sorting descending:

const points = ;
points.sort(function(a, b){return b - a});
// now points contains the highest value
// and points[points.length-1] contains the lowest value

Same as above example but this is for Sorting ascending:

## My Min / Max JavaScript Methods

This function loops through an array comparing each value with the lowest value found:

### Example (Find Min):

function myArrayMin(arr) {
let len = arr.length;
let min = Infinity;
while (len--) {
if (arr[len] < min) {
min = arr[len];
}
}
return min;
}

This function loops through an array comparing each value with the highest value found:

below example(almost same as above loop) for find max:

## Sorting Object Arrays

JavaScript arrays often contain objects:

const cars = [
{type:"Volvo", year:2016},
{type:"Saab", year:2001},
{type:"BMW", year:2010}
];

Even if objects have properties of different data types, the `sort()` method can be used to sort the array.

The solution is to write a compare function to compare the property values: