-
Notifications
You must be signed in to change notification settings - Fork 64
/
Copy pathAlmost Even.js
23 lines (20 loc) · 926 Bytes
/
Almost Even.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/*
Description:
We need the ability to divide an unknown integer into a given number of even parts — or at least as even as they can be. The sum of the parts should be the original value, but each part should be an integer, and they should be as close as possible.
Example code:
splitInteger(20, 6) // returns [3, 3, 3, 3, 4, 4]
Complete the function so that it returns an array of integer representing the parts. Ignoring the order of the parts, there is only one valid solution for each input to your function!
(Also, there is no reason to test for edge cases: the input to your function will always be valid for this kata.)
*/
var splitInteger = function(num, parts) {
let n =Math.floor(num/parts)
const arr = [];
for (let i=0;i<parts;i++){
arr.push(n)
}
if (arr.reduce((a,b)=>a+b,0)===num) return arr
for (let i=0;i<parts;i++){
arr[i]++
if (arr.reduce((a,b)=>a+b,0)===num) return arr
}
}