Thanks to visit codestin.com
Credit goes to github.com

Skip to content
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 4 additions & 13 deletions Maths/AverageMedian.js
Original file line number Diff line number Diff line change
@@ -1,14 +1,5 @@
/*
* Median: https://en.wikipedia.org/wiki/Median
*
* function averageMedian
* to find the median value of an array of numbers
* the numbers in an array will be sorted in ascending order by the function sortNumbers
* if the length of the array is even number, the median value will be the average of the two middle numbers
* else if the length of the array is odd number, the median value will be the middle number in the array
*/

const averageMedian = (numbers) => {
const averageMedian = (_numbers) => {
Comment thread
raklaptudirm marked this conversation as resolved.
Outdated
let numbers = [..._numbers];
Comment thread
raklaptudirm marked this conversation as resolved.
Outdated
let median = 0
const numLength = numbers.length
numbers = numbers.sort(sortNumbers)
Expand All @@ -19,11 +10,11 @@ const averageMedian = (numbers) => {
median = numbers[(numLength - 1) / 2]
}

return median
return median;
}

const sortNumbers = (num1, num2) => {
return num1 - num2
}

export { averageMedian }
export { averageMedian }
Comment thread
raklaptudirm marked this conversation as resolved.
Outdated
6 changes: 6 additions & 0 deletions Maths/test/AverageMedian.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,3 +19,9 @@ test('should return the median of an array of numbers:', () => {
const medianValue = averageMedian([1, 2, 3, 4, 6, 8])
expect(medianValue).toBe(3.5)
})

test('shouldn`t change source array', () => {
const sourceArray = [3, 2, 1, 4, 6, 8];
averageMedian(sourceArray)
expect(sourceArray).toEqual([3, 2, 1, 4, 6, 8]);
})
Comment thread
raklaptudirm marked this conversation as resolved.
Outdated