-
-
Notifications
You must be signed in to change notification settings - Fork 283
Expand file tree
/
Copy pathinvert.js
More file actions
35 lines (24 loc) · 1.09 KB
/
invert.js
File metadata and controls
35 lines (24 loc) · 1.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// Let's define how invert should work
// Given an object
// When invert is passed this object
// Then it should swap the keys and values in the object
// E.g. invert({x : 10, y : 20}), target output: {"10": "x", "20": "y"}
function invert(obj) {
const invertedObj = {};
for (const [key, value] of Object.entries(obj)) {
invertedObj[value] = key;
}
return invertedObj;
}
// a) What is the current return value when invert is called with { a : 1 }
//["a",1]
// b) What is the current return value when invert is called with { a: 1, b: 2 }
//[[ "a", 1], ["b", 2]]
// c) What is the target return value when invert is called with {a : 1, b: 2}
//{"1":a,"2":b}
// c) What does Object.entries return? Why is it needed in this program?
//returns an array so we can access each element of it so we can swap their order
// d) Explain why the current return value is different from the target output
//it creates a new key:value pair with the key being "key",also it doesnt invert the key with the value
// e) Fix the implementation of invert (and write tests to prove it's fixed!)
module.exports = invert;