Free Code Camp - PairwiseFind the max. difference between two array elements a[j] and a[i] such that j > iExtract higher value of pair from JavaScript arrayPairwise programming challenge - Free code campFinding an equilibrium index in an int arrayHackerRank university codesprint array constructionFind all triplets in array that add up to a given sumThree sum using binary searchShuffling an array keeping some elements fixedFind value that occurs in odd number of elementsSimple function returning 1 if the Mean = Mode, or 0 if not
Which Article Helped Get Rid of Technobabble in RPGs?
Plot of a tornado shape like surface
Change the color of a single dot in `ddot` symbol
Why is it that I can sometimes guess the next note?
How could a planet have erratic days?
What is Cash Advance APR?
How to get directions in deep space?
Why is so much work done on numerical verification of the Riemann Hypothesis?
What does Apple's new App Store requirement mean
Is this toilet slogan correct usage of the English language?
Does "he squandered his car on drink" sound natural?
How can ping know if my host is down
What is the highest possible scrabble score for placing a single tile
What is the English pronunciation of "pain au chocolat"?
"It doesn't matter" or "it won't matter"?
Quoting Keynes in a lecture
I found an audio circuit and I built it just fine, but I find it a bit too quiet. How do I amplify the output so that it is a bit louder?
Why can't the Brexit deadlock in the UK parliament be solved with a plurality vote?
Mimic lecturing on blackboard, facing audience
15% tax on $7.5k earnings. Is that right?
What is the difference between lands and mana?
The IT department bottlenecks progress, how should I handle this?
It grows, but water kills it
Is it allowed to activate the ability of multiple planeswalkers in a single turn?
Free Code Camp - Pairwise
Find the max. difference between two array elements a[j] and a[i] such that j > iExtract higher value of pair from JavaScript arrayPairwise programming challenge - Free code campFinding an equilibrium index in an int arrayHackerRank university codesprint array constructionFind all triplets in array that add up to a given sumThree sum using binary searchShuffling an array keeping some elements fixedFind value that occurs in odd number of elementsSimple function returning 1 if the Mean = Mode, or 0 if not
$begingroup$
I'm working through the Free Code Camp syllabus and I'm on to Intermediate JavaScript Algorithms. This Pairwise problem was the last challenge in that section. The section came just after "Object Oriented JavaScript." So I figured they were looking for an OO solution, but the instructions included a link to MDN's array.reduce()
. My solution doesn't use array.reduce()
and I'd really appreciate some feedback on what I could have done better to make my code more compact and efficient. It feels a little clunky but passes all the tests.
The instructions
Return the sum of all indices of elements of 'arr' that can be paired
with one other element to form a sum that equals the value in the
second argument 'arg'. If multiple sums are possible, return the
smallest sum. Once an element has been used, it cannot be reused to
pair with another.
For example, pairwise([1, 4, 2, 3, 0, 5], 7) should return 11 because
4, 2, 3 and 5 can be paired with each other to equal 7.
pairwise([1, 3, 2, 4], 4) would only equal 1, because only the first
two elements can be paired to equal 4, and the first element has an
index of 0!
Remember to use RSAP if you get stuck. Try to pair program. Write your
own code.
Here are some helpful links:
Array.reduce()
My Solution
function pairwise(arr, arg)
this.objects = [];
var total = 0;
function Element(value, index)
this.value = value;
this.index = index;
this.used = 0;
for (var i = 0; i < arr.length; i++)
this.objects.push(new Element(arr[i], i));
for (var j = 0; j < objects.length; j++)
if (objects[j].used === 0)
for (var k = 0; k < objects.length; k++)
if (objects[k].used === 0 && objects[k].index != objects[j].index)
if (arg - objects[j].value == objects[k].value)
total = total + objects[j].index + objects[k].index;
objects[j].used = 1;
objects[k].used = 1;
break;
return total;
pairwise([1,1,1], 2);
javascript algorithm object-oriented array
$endgroup$
add a comment |
$begingroup$
I'm working through the Free Code Camp syllabus and I'm on to Intermediate JavaScript Algorithms. This Pairwise problem was the last challenge in that section. The section came just after "Object Oriented JavaScript." So I figured they were looking for an OO solution, but the instructions included a link to MDN's array.reduce()
. My solution doesn't use array.reduce()
and I'd really appreciate some feedback on what I could have done better to make my code more compact and efficient. It feels a little clunky but passes all the tests.
The instructions
Return the sum of all indices of elements of 'arr' that can be paired
with one other element to form a sum that equals the value in the
second argument 'arg'. If multiple sums are possible, return the
smallest sum. Once an element has been used, it cannot be reused to
pair with another.
For example, pairwise([1, 4, 2, 3, 0, 5], 7) should return 11 because
4, 2, 3 and 5 can be paired with each other to equal 7.
pairwise([1, 3, 2, 4], 4) would only equal 1, because only the first
two elements can be paired to equal 4, and the first element has an
index of 0!
Remember to use RSAP if you get stuck. Try to pair program. Write your
own code.
Here are some helpful links:
Array.reduce()
My Solution
function pairwise(arr, arg)
this.objects = [];
var total = 0;
function Element(value, index)
this.value = value;
this.index = index;
this.used = 0;
for (var i = 0; i < arr.length; i++)
this.objects.push(new Element(arr[i], i));
for (var j = 0; j < objects.length; j++)
if (objects[j].used === 0)
for (var k = 0; k < objects.length; k++)
if (objects[k].used === 0 && objects[k].index != objects[j].index)
if (arg - objects[j].value == objects[k].value)
total = total + objects[j].index + objects[k].index;
objects[j].used = 1;
objects[k].used = 1;
break;
return total;
pairwise([1,1,1], 2);
javascript algorithm object-oriented array
$endgroup$
$begingroup$
Shouldn't the first one return a 4? The instruction did say "If multiple sums are possible, return the smallest sum." and nothing about when multiple sums can be added together or not.
$endgroup$
– Joseph
Jul 30 '15 at 17:04
add a comment |
$begingroup$
I'm working through the Free Code Camp syllabus and I'm on to Intermediate JavaScript Algorithms. This Pairwise problem was the last challenge in that section. The section came just after "Object Oriented JavaScript." So I figured they were looking for an OO solution, but the instructions included a link to MDN's array.reduce()
. My solution doesn't use array.reduce()
and I'd really appreciate some feedback on what I could have done better to make my code more compact and efficient. It feels a little clunky but passes all the tests.
The instructions
Return the sum of all indices of elements of 'arr' that can be paired
with one other element to form a sum that equals the value in the
second argument 'arg'. If multiple sums are possible, return the
smallest sum. Once an element has been used, it cannot be reused to
pair with another.
For example, pairwise([1, 4, 2, 3, 0, 5], 7) should return 11 because
4, 2, 3 and 5 can be paired with each other to equal 7.
pairwise([1, 3, 2, 4], 4) would only equal 1, because only the first
two elements can be paired to equal 4, and the first element has an
index of 0!
Remember to use RSAP if you get stuck. Try to pair program. Write your
own code.
Here are some helpful links:
Array.reduce()
My Solution
function pairwise(arr, arg)
this.objects = [];
var total = 0;
function Element(value, index)
this.value = value;
this.index = index;
this.used = 0;
for (var i = 0; i < arr.length; i++)
this.objects.push(new Element(arr[i], i));
for (var j = 0; j < objects.length; j++)
if (objects[j].used === 0)
for (var k = 0; k < objects.length; k++)
if (objects[k].used === 0 && objects[k].index != objects[j].index)
if (arg - objects[j].value == objects[k].value)
total = total + objects[j].index + objects[k].index;
objects[j].used = 1;
objects[k].used = 1;
break;
return total;
pairwise([1,1,1], 2);
javascript algorithm object-oriented array
$endgroup$
I'm working through the Free Code Camp syllabus and I'm on to Intermediate JavaScript Algorithms. This Pairwise problem was the last challenge in that section. The section came just after "Object Oriented JavaScript." So I figured they were looking for an OO solution, but the instructions included a link to MDN's array.reduce()
. My solution doesn't use array.reduce()
and I'd really appreciate some feedback on what I could have done better to make my code more compact and efficient. It feels a little clunky but passes all the tests.
The instructions
Return the sum of all indices of elements of 'arr' that can be paired
with one other element to form a sum that equals the value in the
second argument 'arg'. If multiple sums are possible, return the
smallest sum. Once an element has been used, it cannot be reused to
pair with another.
For example, pairwise([1, 4, 2, 3, 0, 5], 7) should return 11 because
4, 2, 3 and 5 can be paired with each other to equal 7.
pairwise([1, 3, 2, 4], 4) would only equal 1, because only the first
two elements can be paired to equal 4, and the first element has an
index of 0!
Remember to use RSAP if you get stuck. Try to pair program. Write your
own code.
Here are some helpful links:
Array.reduce()
My Solution
function pairwise(arr, arg)
this.objects = [];
var total = 0;
function Element(value, index)
this.value = value;
this.index = index;
this.used = 0;
for (var i = 0; i < arr.length; i++)
this.objects.push(new Element(arr[i], i));
for (var j = 0; j < objects.length; j++)
if (objects[j].used === 0)
for (var k = 0; k < objects.length; k++)
if (objects[k].used === 0 && objects[k].index != objects[j].index)
if (arg - objects[j].value == objects[k].value)
total = total + objects[j].index + objects[k].index;
objects[j].used = 1;
objects[k].used = 1;
break;
return total;
pairwise([1,1,1], 2);
javascript algorithm object-oriented array
javascript algorithm object-oriented array
edited Jul 29 '15 at 16:45
Jamal♦
30.4k11121227
30.4k11121227
asked Jul 29 '15 at 11:03
John BehanJohn Behan
1335
1335
$begingroup$
Shouldn't the first one return a 4? The instruction did say "If multiple sums are possible, return the smallest sum." and nothing about when multiple sums can be added together or not.
$endgroup$
– Joseph
Jul 30 '15 at 17:04
add a comment |
$begingroup$
Shouldn't the first one return a 4? The instruction did say "If multiple sums are possible, return the smallest sum." and nothing about when multiple sums can be added together or not.
$endgroup$
– Joseph
Jul 30 '15 at 17:04
$begingroup$
Shouldn't the first one return a 4? The instruction did say "If multiple sums are possible, return the smallest sum." and nothing about when multiple sums can be added together or not.
$endgroup$
– Joseph
Jul 30 '15 at 17:04
$begingroup$
Shouldn't the first one return a 4? The instruction did say "If multiple sums are possible, return the smallest sum." and nothing about when multiple sums can be added together or not.
$endgroup$
– Joseph
Jul 30 '15 at 17:04
add a comment |
7 Answers
7
active
oldest
votes
$begingroup$
I looked through your code and it is a valid solution, but you could reduce your code base by better leveraging the functions that JavaScript already provides, such as Array.prototype.indexOf()
.
For example, instead of building a new class-like-function (Element
) to track the appearance of a certain index, I simply made a deep copy of the the initial array and parsed it with indexOf()
.
Moreover, in your code, when you first declare this.objects = []
, this
actually refers to the global scope (window object
). As you can see, you are calling pairwise without building a new instance (new
keyword). In this case, thus the this
keyword is bound to the global window object.
Please find below my take on it:
function pairwise(arr, arg)
var result = 0,
newArr = [],
//Used to hold the indices that we have already used to form our sum
indices = [];
//Loop through arr and create a deep copy of it in newArr
for(var k = 0; k < arr.length; k++)
newArr.push(arr[k]);
//Loop through arr
for(var i = 0; i < arr.length; i++)
//Loop through newArr
for(var j = 0; j < newArr.length; j++)
//Since we want to add different elements of the array, we want to avoid adding the same element
if(i !== j)
//If the sum of two elements is equal to arg AND the indices that we have in i and j are not part of the indices array
//Indices array is used to hold the already used indices, thus ensuring the accurate parsing of the parameters
if(arr[i] + newArr[j] === arg && indices.indexOf(i) === -1 && indices.indexOf(j) === -1)
//Sum the indices up
result += i + j;
//Push the indices in the indices array in order to not use them in further iterations
indices.push(i, j);
return result;
pairwise([1,4,2,3,0,5], 7);
$endgroup$
$begingroup$
Hi Vlad—thanks for solution. I am going through your code to try to learn from it. Could you explain howif(i !== j)
the first conditional, is comparing anything but the iterators?
$endgroup$
– Antonio Pavicevac-Ortiz
May 9 '16 at 14:57
1
$begingroup$
In my solution,newArr
is a deep copy of thearr
initially passed to thepairwise
function. Thus, when the two iterator variables (i
&j
) have the same value, while iterating through different copies of the same object, they would actually add up the exact same number of the array, which is not a valid case for the aforementioned scenario.
$endgroup$
– vladzam
May 10 '16 at 12:44
add a comment |
$begingroup$
Vlad Z answer is correct but freecodecamp has weird wording on this problem. I used a similar answer but was failing on this test:
expect(pairwise([0, 0, 0, 0, 1, 1], 1)).to.equal(10);
My problem and the problem with Vlad Zs solution is that 0,1 -> indexes (0 and 4) and 0,1 indexes(1 and 5) are both acceptable and should return 10.
I would use Vlad's solution but sub in this function instead of indexOf === -1 to check if a pair exists already:
function checkPairExists(value,position,pairsArray)
for(var i = 0; i < pairsArray.length; i++)
if (pairsArray[i].value === value && pairsArray[i].position === position)
return true;
return false;
$endgroup$
add a comment |
$begingroup$
This function implementation uses the "reduce" method to get the sum of the indexes and it fullfills all Free Code Camp tests.
function pairwise(arr, arg)
return arr.reduce((sum, value1, index1) =>
arr.slice(index1 + 1).forEach((value2, index2) =>
if (arr[index1] + arr[index1 + 1 + index2] === arg)
arr[index1] = arr[index1 + 1 + index2] = NaN;
sum += index1 + index1 + 1 + index2;
);
return sum;
, 0);
$endgroup$
add a comment |
$begingroup$
I came to the same conclusion as Piotr, but with a slight improvement - dropping one more un-necessary check. See comments in code below:
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i < arr.length - 1; i++)
for (var j=i+1; j < arr.length; j++)
//No need to check for less than arg, used elements are naturally eliminated
if (arr[i] + arr[j] === arg)
sum += i + j;
arr[i] = arr[j] = arg + 1; //Set the used elements to higher than arg e.g. arg + 1
return sum;
pairwise([1,4,2,3,0,5], 7);
$endgroup$
add a comment |
$begingroup$
The requirements are broken down into:
- Return the sum of all indices of elements of 'arr' that can be paired with one other element to form a sum that equals the value in the second argument 'arg'.
- If multiple sums are possible, return the smallest sum. Once an element has been used
- Once an element has been used, it cannot be reused to pair with another.
The first bullet point is easy enough to understand. We find pairs that sum up to the total, and sum up the indices.
However, your example contradicts the second bullet point. If multiple sums are found, it should return the smallest. 4 and 3 are 1 and 3 which results to 4. 2 and 5 are 2 and 5 which results to 7. The result should be 4 in the first example.
So here's my take on it
function pairwise(arr, total)
// For each item in the array
var sums = arr.reduce(function (indexSum, firstNumber, firstIndex)
// Collect the pair's index which causes the numbers to sum to total
var secondIndices = arr.slice(firstIndex + 1).reduce(function (secondIndices, secondNumber, i)
if (firstNumber + secondNumber === total) secondIndices.push(firstIndex + i + 1);
return secondIndices;
, []);
// Add to our collection the sum this iteration's index and
// the pair indices
return indexSum.concat(secondIndices.map(function (secondIndex)
return secondIndex + firstIndex
));
, []);
// In all the items, find the smallest sum
return Math.min.apply(null, sums);
console.log(pairwise([1, 4, 2, 3, 0, 5], 7));
console.log(pairwise([1, 3, 2, 4], 4));
Regarding bullet point 3, I would care less if a number was reused, like in the case of 6 in [4, 4, 2]
or say [4, 2, 9, 9, 4]
because any number that's going to pair with it after the first established pair will have a higher index sum anyways.
$endgroup$
$begingroup$
Thanks for the great reply, the way I read the second requirement - returning smallest sum, was that if the target could be reached by two calculations sharing one number then we should use the calculation whose sum of indices is smallest. For example:pairwise([0,1,1], 1)
should return 1, even though it is possible to use the last number in the array with the 0 to get an answer of 2, we should use the smallest index sum. Thanks again though and you managed to usearray.reduce()!
I would never have gotten that.
$endgroup$
– John Behan
Jul 31 '15 at 6:40
add a comment |
$begingroup$
The solution below is very compact. It avoids unnecessary checks and loops only through the relevant elements. You can check the working codepen here:
http://codepen.io/PiotrBerebecki/pen/RRGaBZ.
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i<arr.length-1; i++)
for (var j=i+1; j<arr.length; j++)
if (arr[i] <= arg && arr[j] <= arg && arr[i] + arr[j] == arg)
sum += i+j;
arr[i] = arr[j] = NaN;
return sum;
console.log( pairwise([1, 1, 0, 2], 2) ) // should return 6
Under the hood:
- Start looping from the element with index (
i
) = 0. - Add a second loop only for the elements which are later in the array. Their index
j
is always higher thani
as we are adding 1 toi
. - If both elements (numbers) are less than or equal to to the
arg
, check if their sum equals to thearg
. This avoids checking the sum if either of the numbers are greater than thearg
. - If the pair has been found then change their values to
NaN
to avoid further checks and duplication.
$endgroup$
add a comment |
$begingroup$
Old forum but wanted to contribute an ES6 solution
function pairwise(arr, arg)
let sum=0;
// ES6
for(let i in arr)
for(let j in arr)
if(i!=j)
if ((arr[i]+arr[j]) === arg)
sum += (Number(i)+Number(j));
arr[i] = arr[j] = arg+1;
return sum;
pairwise([1, 4, 2, 3, 0, 5], 7)
New contributor
$endgroup$
add a comment |
Your Answer
StackExchange.ifUsing("editor", function ()
return StackExchange.using("mathjaxEditing", function ()
StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
);
);
, "mathjax-editing");
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "196"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f98448%2ffree-code-camp-pairwise%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
7 Answers
7
active
oldest
votes
7 Answers
7
active
oldest
votes
active
oldest
votes
active
oldest
votes
$begingroup$
I looked through your code and it is a valid solution, but you could reduce your code base by better leveraging the functions that JavaScript already provides, such as Array.prototype.indexOf()
.
For example, instead of building a new class-like-function (Element
) to track the appearance of a certain index, I simply made a deep copy of the the initial array and parsed it with indexOf()
.
Moreover, in your code, when you first declare this.objects = []
, this
actually refers to the global scope (window object
). As you can see, you are calling pairwise without building a new instance (new
keyword). In this case, thus the this
keyword is bound to the global window object.
Please find below my take on it:
function pairwise(arr, arg)
var result = 0,
newArr = [],
//Used to hold the indices that we have already used to form our sum
indices = [];
//Loop through arr and create a deep copy of it in newArr
for(var k = 0; k < arr.length; k++)
newArr.push(arr[k]);
//Loop through arr
for(var i = 0; i < arr.length; i++)
//Loop through newArr
for(var j = 0; j < newArr.length; j++)
//Since we want to add different elements of the array, we want to avoid adding the same element
if(i !== j)
//If the sum of two elements is equal to arg AND the indices that we have in i and j are not part of the indices array
//Indices array is used to hold the already used indices, thus ensuring the accurate parsing of the parameters
if(arr[i] + newArr[j] === arg && indices.indexOf(i) === -1 && indices.indexOf(j) === -1)
//Sum the indices up
result += i + j;
//Push the indices in the indices array in order to not use them in further iterations
indices.push(i, j);
return result;
pairwise([1,4,2,3,0,5], 7);
$endgroup$
$begingroup$
Hi Vlad—thanks for solution. I am going through your code to try to learn from it. Could you explain howif(i !== j)
the first conditional, is comparing anything but the iterators?
$endgroup$
– Antonio Pavicevac-Ortiz
May 9 '16 at 14:57
1
$begingroup$
In my solution,newArr
is a deep copy of thearr
initially passed to thepairwise
function. Thus, when the two iterator variables (i
&j
) have the same value, while iterating through different copies of the same object, they would actually add up the exact same number of the array, which is not a valid case for the aforementioned scenario.
$endgroup$
– vladzam
May 10 '16 at 12:44
add a comment |
$begingroup$
I looked through your code and it is a valid solution, but you could reduce your code base by better leveraging the functions that JavaScript already provides, such as Array.prototype.indexOf()
.
For example, instead of building a new class-like-function (Element
) to track the appearance of a certain index, I simply made a deep copy of the the initial array and parsed it with indexOf()
.
Moreover, in your code, when you first declare this.objects = []
, this
actually refers to the global scope (window object
). As you can see, you are calling pairwise without building a new instance (new
keyword). In this case, thus the this
keyword is bound to the global window object.
Please find below my take on it:
function pairwise(arr, arg)
var result = 0,
newArr = [],
//Used to hold the indices that we have already used to form our sum
indices = [];
//Loop through arr and create a deep copy of it in newArr
for(var k = 0; k < arr.length; k++)
newArr.push(arr[k]);
//Loop through arr
for(var i = 0; i < arr.length; i++)
//Loop through newArr
for(var j = 0; j < newArr.length; j++)
//Since we want to add different elements of the array, we want to avoid adding the same element
if(i !== j)
//If the sum of two elements is equal to arg AND the indices that we have in i and j are not part of the indices array
//Indices array is used to hold the already used indices, thus ensuring the accurate parsing of the parameters
if(arr[i] + newArr[j] === arg && indices.indexOf(i) === -1 && indices.indexOf(j) === -1)
//Sum the indices up
result += i + j;
//Push the indices in the indices array in order to not use them in further iterations
indices.push(i, j);
return result;
pairwise([1,4,2,3,0,5], 7);
$endgroup$
$begingroup$
Hi Vlad—thanks for solution. I am going through your code to try to learn from it. Could you explain howif(i !== j)
the first conditional, is comparing anything but the iterators?
$endgroup$
– Antonio Pavicevac-Ortiz
May 9 '16 at 14:57
1
$begingroup$
In my solution,newArr
is a deep copy of thearr
initially passed to thepairwise
function. Thus, when the two iterator variables (i
&j
) have the same value, while iterating through different copies of the same object, they would actually add up the exact same number of the array, which is not a valid case for the aforementioned scenario.
$endgroup$
– vladzam
May 10 '16 at 12:44
add a comment |
$begingroup$
I looked through your code and it is a valid solution, but you could reduce your code base by better leveraging the functions that JavaScript already provides, such as Array.prototype.indexOf()
.
For example, instead of building a new class-like-function (Element
) to track the appearance of a certain index, I simply made a deep copy of the the initial array and parsed it with indexOf()
.
Moreover, in your code, when you first declare this.objects = []
, this
actually refers to the global scope (window object
). As you can see, you are calling pairwise without building a new instance (new
keyword). In this case, thus the this
keyword is bound to the global window object.
Please find below my take on it:
function pairwise(arr, arg)
var result = 0,
newArr = [],
//Used to hold the indices that we have already used to form our sum
indices = [];
//Loop through arr and create a deep copy of it in newArr
for(var k = 0; k < arr.length; k++)
newArr.push(arr[k]);
//Loop through arr
for(var i = 0; i < arr.length; i++)
//Loop through newArr
for(var j = 0; j < newArr.length; j++)
//Since we want to add different elements of the array, we want to avoid adding the same element
if(i !== j)
//If the sum of two elements is equal to arg AND the indices that we have in i and j are not part of the indices array
//Indices array is used to hold the already used indices, thus ensuring the accurate parsing of the parameters
if(arr[i] + newArr[j] === arg && indices.indexOf(i) === -1 && indices.indexOf(j) === -1)
//Sum the indices up
result += i + j;
//Push the indices in the indices array in order to not use them in further iterations
indices.push(i, j);
return result;
pairwise([1,4,2,3,0,5], 7);
$endgroup$
I looked through your code and it is a valid solution, but you could reduce your code base by better leveraging the functions that JavaScript already provides, such as Array.prototype.indexOf()
.
For example, instead of building a new class-like-function (Element
) to track the appearance of a certain index, I simply made a deep copy of the the initial array and parsed it with indexOf()
.
Moreover, in your code, when you first declare this.objects = []
, this
actually refers to the global scope (window object
). As you can see, you are calling pairwise without building a new instance (new
keyword). In this case, thus the this
keyword is bound to the global window object.
Please find below my take on it:
function pairwise(arr, arg)
var result = 0,
newArr = [],
//Used to hold the indices that we have already used to form our sum
indices = [];
//Loop through arr and create a deep copy of it in newArr
for(var k = 0; k < arr.length; k++)
newArr.push(arr[k]);
//Loop through arr
for(var i = 0; i < arr.length; i++)
//Loop through newArr
for(var j = 0; j < newArr.length; j++)
//Since we want to add different elements of the array, we want to avoid adding the same element
if(i !== j)
//If the sum of two elements is equal to arg AND the indices that we have in i and j are not part of the indices array
//Indices array is used to hold the already used indices, thus ensuring the accurate parsing of the parameters
if(arr[i] + newArr[j] === arg && indices.indexOf(i) === -1 && indices.indexOf(j) === -1)
//Sum the indices up
result += i + j;
//Push the indices in the indices array in order to not use them in further iterations
indices.push(i, j);
return result;
pairwise([1,4,2,3,0,5], 7);
answered Jul 31 '15 at 9:03
vladzamvladzam
1461
1461
$begingroup$
Hi Vlad—thanks for solution. I am going through your code to try to learn from it. Could you explain howif(i !== j)
the first conditional, is comparing anything but the iterators?
$endgroup$
– Antonio Pavicevac-Ortiz
May 9 '16 at 14:57
1
$begingroup$
In my solution,newArr
is a deep copy of thearr
initially passed to thepairwise
function. Thus, when the two iterator variables (i
&j
) have the same value, while iterating through different copies of the same object, they would actually add up the exact same number of the array, which is not a valid case for the aforementioned scenario.
$endgroup$
– vladzam
May 10 '16 at 12:44
add a comment |
$begingroup$
Hi Vlad—thanks for solution. I am going through your code to try to learn from it. Could you explain howif(i !== j)
the first conditional, is comparing anything but the iterators?
$endgroup$
– Antonio Pavicevac-Ortiz
May 9 '16 at 14:57
1
$begingroup$
In my solution,newArr
is a deep copy of thearr
initially passed to thepairwise
function. Thus, when the two iterator variables (i
&j
) have the same value, while iterating through different copies of the same object, they would actually add up the exact same number of the array, which is not a valid case for the aforementioned scenario.
$endgroup$
– vladzam
May 10 '16 at 12:44
$begingroup$
Hi Vlad—thanks for solution. I am going through your code to try to learn from it. Could you explain how
if(i !== j)
the first conditional, is comparing anything but the iterators?$endgroup$
– Antonio Pavicevac-Ortiz
May 9 '16 at 14:57
$begingroup$
Hi Vlad—thanks for solution. I am going through your code to try to learn from it. Could you explain how
if(i !== j)
the first conditional, is comparing anything but the iterators?$endgroup$
– Antonio Pavicevac-Ortiz
May 9 '16 at 14:57
1
1
$begingroup$
In my solution,
newArr
is a deep copy of the arr
initially passed to the pairwise
function. Thus, when the two iterator variables (i
& j
) have the same value, while iterating through different copies of the same object, they would actually add up the exact same number of the array, which is not a valid case for the aforementioned scenario.$endgroup$
– vladzam
May 10 '16 at 12:44
$begingroup$
In my solution,
newArr
is a deep copy of the arr
initially passed to the pairwise
function. Thus, when the two iterator variables (i
& j
) have the same value, while iterating through different copies of the same object, they would actually add up the exact same number of the array, which is not a valid case for the aforementioned scenario.$endgroup$
– vladzam
May 10 '16 at 12:44
add a comment |
$begingroup$
Vlad Z answer is correct but freecodecamp has weird wording on this problem. I used a similar answer but was failing on this test:
expect(pairwise([0, 0, 0, 0, 1, 1], 1)).to.equal(10);
My problem and the problem with Vlad Zs solution is that 0,1 -> indexes (0 and 4) and 0,1 indexes(1 and 5) are both acceptable and should return 10.
I would use Vlad's solution but sub in this function instead of indexOf === -1 to check if a pair exists already:
function checkPairExists(value,position,pairsArray)
for(var i = 0; i < pairsArray.length; i++)
if (pairsArray[i].value === value && pairsArray[i].position === position)
return true;
return false;
$endgroup$
add a comment |
$begingroup$
Vlad Z answer is correct but freecodecamp has weird wording on this problem. I used a similar answer but was failing on this test:
expect(pairwise([0, 0, 0, 0, 1, 1], 1)).to.equal(10);
My problem and the problem with Vlad Zs solution is that 0,1 -> indexes (0 and 4) and 0,1 indexes(1 and 5) are both acceptable and should return 10.
I would use Vlad's solution but sub in this function instead of indexOf === -1 to check if a pair exists already:
function checkPairExists(value,position,pairsArray)
for(var i = 0; i < pairsArray.length; i++)
if (pairsArray[i].value === value && pairsArray[i].position === position)
return true;
return false;
$endgroup$
add a comment |
$begingroup$
Vlad Z answer is correct but freecodecamp has weird wording on this problem. I used a similar answer but was failing on this test:
expect(pairwise([0, 0, 0, 0, 1, 1], 1)).to.equal(10);
My problem and the problem with Vlad Zs solution is that 0,1 -> indexes (0 and 4) and 0,1 indexes(1 and 5) are both acceptable and should return 10.
I would use Vlad's solution but sub in this function instead of indexOf === -1 to check if a pair exists already:
function checkPairExists(value,position,pairsArray)
for(var i = 0; i < pairsArray.length; i++)
if (pairsArray[i].value === value && pairsArray[i].position === position)
return true;
return false;
$endgroup$
Vlad Z answer is correct but freecodecamp has weird wording on this problem. I used a similar answer but was failing on this test:
expect(pairwise([0, 0, 0, 0, 1, 1], 1)).to.equal(10);
My problem and the problem with Vlad Zs solution is that 0,1 -> indexes (0 and 4) and 0,1 indexes(1 and 5) are both acceptable and should return 10.
I would use Vlad's solution but sub in this function instead of indexOf === -1 to check if a pair exists already:
function checkPairExists(value,position,pairsArray)
for(var i = 0; i < pairsArray.length; i++)
if (pairsArray[i].value === value && pairsArray[i].position === position)
return true;
return false;
edited Aug 3 '15 at 15:10
Malachi♦
25.6k774176
25.6k774176
answered Aug 3 '15 at 15:00
Frank TreadwellFrank Treadwell
1211
1211
add a comment |
add a comment |
$begingroup$
This function implementation uses the "reduce" method to get the sum of the indexes and it fullfills all Free Code Camp tests.
function pairwise(arr, arg)
return arr.reduce((sum, value1, index1) =>
arr.slice(index1 + 1).forEach((value2, index2) =>
if (arr[index1] + arr[index1 + 1 + index2] === arg)
arr[index1] = arr[index1 + 1 + index2] = NaN;
sum += index1 + index1 + 1 + index2;
);
return sum;
, 0);
$endgroup$
add a comment |
$begingroup$
This function implementation uses the "reduce" method to get the sum of the indexes and it fullfills all Free Code Camp tests.
function pairwise(arr, arg)
return arr.reduce((sum, value1, index1) =>
arr.slice(index1 + 1).forEach((value2, index2) =>
if (arr[index1] + arr[index1 + 1 + index2] === arg)
arr[index1] = arr[index1 + 1 + index2] = NaN;
sum += index1 + index1 + 1 + index2;
);
return sum;
, 0);
$endgroup$
add a comment |
$begingroup$
This function implementation uses the "reduce" method to get the sum of the indexes and it fullfills all Free Code Camp tests.
function pairwise(arr, arg)
return arr.reduce((sum, value1, index1) =>
arr.slice(index1 + 1).forEach((value2, index2) =>
if (arr[index1] + arr[index1 + 1 + index2] === arg)
arr[index1] = arr[index1 + 1 + index2] = NaN;
sum += index1 + index1 + 1 + index2;
);
return sum;
, 0);
$endgroup$
This function implementation uses the "reduce" method to get the sum of the indexes and it fullfills all Free Code Camp tests.
function pairwise(arr, arg)
return arr.reduce((sum, value1, index1) =>
arr.slice(index1 + 1).forEach((value2, index2) =>
if (arr[index1] + arr[index1 + 1 + index2] === arg)
arr[index1] = arr[index1 + 1 + index2] = NaN;
sum += index1 + index1 + 1 + index2;
);
return sum;
, 0);
answered Jul 13 '16 at 10:19
Paulo BotoPaulo Boto
212
212
add a comment |
add a comment |
$begingroup$
I came to the same conclusion as Piotr, but with a slight improvement - dropping one more un-necessary check. See comments in code below:
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i < arr.length - 1; i++)
for (var j=i+1; j < arr.length; j++)
//No need to check for less than arg, used elements are naturally eliminated
if (arr[i] + arr[j] === arg)
sum += i + j;
arr[i] = arr[j] = arg + 1; //Set the used elements to higher than arg e.g. arg + 1
return sum;
pairwise([1,4,2,3,0,5], 7);
$endgroup$
add a comment |
$begingroup$
I came to the same conclusion as Piotr, but with a slight improvement - dropping one more un-necessary check. See comments in code below:
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i < arr.length - 1; i++)
for (var j=i+1; j < arr.length; j++)
//No need to check for less than arg, used elements are naturally eliminated
if (arr[i] + arr[j] === arg)
sum += i + j;
arr[i] = arr[j] = arg + 1; //Set the used elements to higher than arg e.g. arg + 1
return sum;
pairwise([1,4,2,3,0,5], 7);
$endgroup$
add a comment |
$begingroup$
I came to the same conclusion as Piotr, but with a slight improvement - dropping one more un-necessary check. See comments in code below:
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i < arr.length - 1; i++)
for (var j=i+1; j < arr.length; j++)
//No need to check for less than arg, used elements are naturally eliminated
if (arr[i] + arr[j] === arg)
sum += i + j;
arr[i] = arr[j] = arg + 1; //Set the used elements to higher than arg e.g. arg + 1
return sum;
pairwise([1,4,2,3,0,5], 7);
$endgroup$
I came to the same conclusion as Piotr, but with a slight improvement - dropping one more un-necessary check. See comments in code below:
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i < arr.length - 1; i++)
for (var j=i+1; j < arr.length; j++)
//No need to check for less than arg, used elements are naturally eliminated
if (arr[i] + arr[j] === arg)
sum += i + j;
arr[i] = arr[j] = arg + 1; //Set the used elements to higher than arg e.g. arg + 1
return sum;
pairwise([1,4,2,3,0,5], 7);
answered Oct 31 '16 at 14:58
balachbalach
211
211
add a comment |
add a comment |
$begingroup$
The requirements are broken down into:
- Return the sum of all indices of elements of 'arr' that can be paired with one other element to form a sum that equals the value in the second argument 'arg'.
- If multiple sums are possible, return the smallest sum. Once an element has been used
- Once an element has been used, it cannot be reused to pair with another.
The first bullet point is easy enough to understand. We find pairs that sum up to the total, and sum up the indices.
However, your example contradicts the second bullet point. If multiple sums are found, it should return the smallest. 4 and 3 are 1 and 3 which results to 4. 2 and 5 are 2 and 5 which results to 7. The result should be 4 in the first example.
So here's my take on it
function pairwise(arr, total)
// For each item in the array
var sums = arr.reduce(function (indexSum, firstNumber, firstIndex)
// Collect the pair's index which causes the numbers to sum to total
var secondIndices = arr.slice(firstIndex + 1).reduce(function (secondIndices, secondNumber, i)
if (firstNumber + secondNumber === total) secondIndices.push(firstIndex + i + 1);
return secondIndices;
, []);
// Add to our collection the sum this iteration's index and
// the pair indices
return indexSum.concat(secondIndices.map(function (secondIndex)
return secondIndex + firstIndex
));
, []);
// In all the items, find the smallest sum
return Math.min.apply(null, sums);
console.log(pairwise([1, 4, 2, 3, 0, 5], 7));
console.log(pairwise([1, 3, 2, 4], 4));
Regarding bullet point 3, I would care less if a number was reused, like in the case of 6 in [4, 4, 2]
or say [4, 2, 9, 9, 4]
because any number that's going to pair with it after the first established pair will have a higher index sum anyways.
$endgroup$
$begingroup$
Thanks for the great reply, the way I read the second requirement - returning smallest sum, was that if the target could be reached by two calculations sharing one number then we should use the calculation whose sum of indices is smallest. For example:pairwise([0,1,1], 1)
should return 1, even though it is possible to use the last number in the array with the 0 to get an answer of 2, we should use the smallest index sum. Thanks again though and you managed to usearray.reduce()!
I would never have gotten that.
$endgroup$
– John Behan
Jul 31 '15 at 6:40
add a comment |
$begingroup$
The requirements are broken down into:
- Return the sum of all indices of elements of 'arr' that can be paired with one other element to form a sum that equals the value in the second argument 'arg'.
- If multiple sums are possible, return the smallest sum. Once an element has been used
- Once an element has been used, it cannot be reused to pair with another.
The first bullet point is easy enough to understand. We find pairs that sum up to the total, and sum up the indices.
However, your example contradicts the second bullet point. If multiple sums are found, it should return the smallest. 4 and 3 are 1 and 3 which results to 4. 2 and 5 are 2 and 5 which results to 7. The result should be 4 in the first example.
So here's my take on it
function pairwise(arr, total)
// For each item in the array
var sums = arr.reduce(function (indexSum, firstNumber, firstIndex)
// Collect the pair's index which causes the numbers to sum to total
var secondIndices = arr.slice(firstIndex + 1).reduce(function (secondIndices, secondNumber, i)
if (firstNumber + secondNumber === total) secondIndices.push(firstIndex + i + 1);
return secondIndices;
, []);
// Add to our collection the sum this iteration's index and
// the pair indices
return indexSum.concat(secondIndices.map(function (secondIndex)
return secondIndex + firstIndex
));
, []);
// In all the items, find the smallest sum
return Math.min.apply(null, sums);
console.log(pairwise([1, 4, 2, 3, 0, 5], 7));
console.log(pairwise([1, 3, 2, 4], 4));
Regarding bullet point 3, I would care less if a number was reused, like in the case of 6 in [4, 4, 2]
or say [4, 2, 9, 9, 4]
because any number that's going to pair with it after the first established pair will have a higher index sum anyways.
$endgroup$
$begingroup$
Thanks for the great reply, the way I read the second requirement - returning smallest sum, was that if the target could be reached by two calculations sharing one number then we should use the calculation whose sum of indices is smallest. For example:pairwise([0,1,1], 1)
should return 1, even though it is possible to use the last number in the array with the 0 to get an answer of 2, we should use the smallest index sum. Thanks again though and you managed to usearray.reduce()!
I would never have gotten that.
$endgroup$
– John Behan
Jul 31 '15 at 6:40
add a comment |
$begingroup$
The requirements are broken down into:
- Return the sum of all indices of elements of 'arr' that can be paired with one other element to form a sum that equals the value in the second argument 'arg'.
- If multiple sums are possible, return the smallest sum. Once an element has been used
- Once an element has been used, it cannot be reused to pair with another.
The first bullet point is easy enough to understand. We find pairs that sum up to the total, and sum up the indices.
However, your example contradicts the second bullet point. If multiple sums are found, it should return the smallest. 4 and 3 are 1 and 3 which results to 4. 2 and 5 are 2 and 5 which results to 7. The result should be 4 in the first example.
So here's my take on it
function pairwise(arr, total)
// For each item in the array
var sums = arr.reduce(function (indexSum, firstNumber, firstIndex)
// Collect the pair's index which causes the numbers to sum to total
var secondIndices = arr.slice(firstIndex + 1).reduce(function (secondIndices, secondNumber, i)
if (firstNumber + secondNumber === total) secondIndices.push(firstIndex + i + 1);
return secondIndices;
, []);
// Add to our collection the sum this iteration's index and
// the pair indices
return indexSum.concat(secondIndices.map(function (secondIndex)
return secondIndex + firstIndex
));
, []);
// In all the items, find the smallest sum
return Math.min.apply(null, sums);
console.log(pairwise([1, 4, 2, 3, 0, 5], 7));
console.log(pairwise([1, 3, 2, 4], 4));
Regarding bullet point 3, I would care less if a number was reused, like in the case of 6 in [4, 4, 2]
or say [4, 2, 9, 9, 4]
because any number that's going to pair with it after the first established pair will have a higher index sum anyways.
$endgroup$
The requirements are broken down into:
- Return the sum of all indices of elements of 'arr' that can be paired with one other element to form a sum that equals the value in the second argument 'arg'.
- If multiple sums are possible, return the smallest sum. Once an element has been used
- Once an element has been used, it cannot be reused to pair with another.
The first bullet point is easy enough to understand. We find pairs that sum up to the total, and sum up the indices.
However, your example contradicts the second bullet point. If multiple sums are found, it should return the smallest. 4 and 3 are 1 and 3 which results to 4. 2 and 5 are 2 and 5 which results to 7. The result should be 4 in the first example.
So here's my take on it
function pairwise(arr, total)
// For each item in the array
var sums = arr.reduce(function (indexSum, firstNumber, firstIndex)
// Collect the pair's index which causes the numbers to sum to total
var secondIndices = arr.slice(firstIndex + 1).reduce(function (secondIndices, secondNumber, i)
if (firstNumber + secondNumber === total) secondIndices.push(firstIndex + i + 1);
return secondIndices;
, []);
// Add to our collection the sum this iteration's index and
// the pair indices
return indexSum.concat(secondIndices.map(function (secondIndex)
return secondIndex + firstIndex
));
, []);
// In all the items, find the smallest sum
return Math.min.apply(null, sums);
console.log(pairwise([1, 4, 2, 3, 0, 5], 7));
console.log(pairwise([1, 3, 2, 4], 4));
Regarding bullet point 3, I would care less if a number was reused, like in the case of 6 in [4, 4, 2]
or say [4, 2, 9, 9, 4]
because any number that's going to pair with it after the first established pair will have a higher index sum anyways.
function pairwise(arr, total)
// For each item in the array
var sums = arr.reduce(function (indexSum, firstNumber, firstIndex)
// Collect the pair's index which causes the numbers to sum to total
var secondIndices = arr.slice(firstIndex + 1).reduce(function (secondIndices, secondNumber, i)
if (firstNumber + secondNumber === total) secondIndices.push(firstIndex + i + 1);
return secondIndices;
, []);
// Add to our collection the sum this iteration's index and
// the pair indices
return indexSum.concat(secondIndices.map(function (secondIndex)
return secondIndex + firstIndex
));
, []);
// In all the items, find the smallest sum
return Math.min.apply(null, sums);
console.log(pairwise([1, 4, 2, 3, 0, 5], 7));
console.log(pairwise([1, 3, 2, 4], 4));
function pairwise(arr, total)
// For each item in the array
var sums = arr.reduce(function (indexSum, firstNumber, firstIndex)
// Collect the pair's index which causes the numbers to sum to total
var secondIndices = arr.slice(firstIndex + 1).reduce(function (secondIndices, secondNumber, i)
if (firstNumber + secondNumber === total) secondIndices.push(firstIndex + i + 1);
return secondIndices;
, []);
// Add to our collection the sum this iteration's index and
// the pair indices
return indexSum.concat(secondIndices.map(function (secondIndex)
return secondIndex + firstIndex
));
, []);
// In all the items, find the smallest sum
return Math.min.apply(null, sums);
console.log(pairwise([1, 4, 2, 3, 0, 5], 7));
console.log(pairwise([1, 3, 2, 4], 4));
answered Jul 30 '15 at 17:17
JosephJoseph
22.8k21935
22.8k21935
$begingroup$
Thanks for the great reply, the way I read the second requirement - returning smallest sum, was that if the target could be reached by two calculations sharing one number then we should use the calculation whose sum of indices is smallest. For example:pairwise([0,1,1], 1)
should return 1, even though it is possible to use the last number in the array with the 0 to get an answer of 2, we should use the smallest index sum. Thanks again though and you managed to usearray.reduce()!
I would never have gotten that.
$endgroup$
– John Behan
Jul 31 '15 at 6:40
add a comment |
$begingroup$
Thanks for the great reply, the way I read the second requirement - returning smallest sum, was that if the target could be reached by two calculations sharing one number then we should use the calculation whose sum of indices is smallest. For example:pairwise([0,1,1], 1)
should return 1, even though it is possible to use the last number in the array with the 0 to get an answer of 2, we should use the smallest index sum. Thanks again though and you managed to usearray.reduce()!
I would never have gotten that.
$endgroup$
– John Behan
Jul 31 '15 at 6:40
$begingroup$
Thanks for the great reply, the way I read the second requirement - returning smallest sum, was that if the target could be reached by two calculations sharing one number then we should use the calculation whose sum of indices is smallest. For example:
pairwise([0,1,1], 1)
should return 1, even though it is possible to use the last number in the array with the 0 to get an answer of 2, we should use the smallest index sum. Thanks again though and you managed to use array.reduce()!
I would never have gotten that.$endgroup$
– John Behan
Jul 31 '15 at 6:40
$begingroup$
Thanks for the great reply, the way I read the second requirement - returning smallest sum, was that if the target could be reached by two calculations sharing one number then we should use the calculation whose sum of indices is smallest. For example:
pairwise([0,1,1], 1)
should return 1, even though it is possible to use the last number in the array with the 0 to get an answer of 2, we should use the smallest index sum. Thanks again though and you managed to use array.reduce()!
I would never have gotten that.$endgroup$
– John Behan
Jul 31 '15 at 6:40
add a comment |
$begingroup$
The solution below is very compact. It avoids unnecessary checks and loops only through the relevant elements. You can check the working codepen here:
http://codepen.io/PiotrBerebecki/pen/RRGaBZ.
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i<arr.length-1; i++)
for (var j=i+1; j<arr.length; j++)
if (arr[i] <= arg && arr[j] <= arg && arr[i] + arr[j] == arg)
sum += i+j;
arr[i] = arr[j] = NaN;
return sum;
console.log( pairwise([1, 1, 0, 2], 2) ) // should return 6
Under the hood:
- Start looping from the element with index (
i
) = 0. - Add a second loop only for the elements which are later in the array. Their index
j
is always higher thani
as we are adding 1 toi
. - If both elements (numbers) are less than or equal to to the
arg
, check if their sum equals to thearg
. This avoids checking the sum if either of the numbers are greater than thearg
. - If the pair has been found then change their values to
NaN
to avoid further checks and duplication.
$endgroup$
add a comment |
$begingroup$
The solution below is very compact. It avoids unnecessary checks and loops only through the relevant elements. You can check the working codepen here:
http://codepen.io/PiotrBerebecki/pen/RRGaBZ.
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i<arr.length-1; i++)
for (var j=i+1; j<arr.length; j++)
if (arr[i] <= arg && arr[j] <= arg && arr[i] + arr[j] == arg)
sum += i+j;
arr[i] = arr[j] = NaN;
return sum;
console.log( pairwise([1, 1, 0, 2], 2) ) // should return 6
Under the hood:
- Start looping from the element with index (
i
) = 0. - Add a second loop only for the elements which are later in the array. Their index
j
is always higher thani
as we are adding 1 toi
. - If both elements (numbers) are less than or equal to to the
arg
, check if their sum equals to thearg
. This avoids checking the sum if either of the numbers are greater than thearg
. - If the pair has been found then change their values to
NaN
to avoid further checks and duplication.
$endgroup$
add a comment |
$begingroup$
The solution below is very compact. It avoids unnecessary checks and loops only through the relevant elements. You can check the working codepen here:
http://codepen.io/PiotrBerebecki/pen/RRGaBZ.
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i<arr.length-1; i++)
for (var j=i+1; j<arr.length; j++)
if (arr[i] <= arg && arr[j] <= arg && arr[i] + arr[j] == arg)
sum += i+j;
arr[i] = arr[j] = NaN;
return sum;
console.log( pairwise([1, 1, 0, 2], 2) ) // should return 6
Under the hood:
- Start looping from the element with index (
i
) = 0. - Add a second loop only for the elements which are later in the array. Their index
j
is always higher thani
as we are adding 1 toi
. - If both elements (numbers) are less than or equal to to the
arg
, check if their sum equals to thearg
. This avoids checking the sum if either of the numbers are greater than thearg
. - If the pair has been found then change their values to
NaN
to avoid further checks and duplication.
$endgroup$
The solution below is very compact. It avoids unnecessary checks and loops only through the relevant elements. You can check the working codepen here:
http://codepen.io/PiotrBerebecki/pen/RRGaBZ.
function pairwise(arr, arg)
var sum = 0;
for (var i=0; i<arr.length-1; i++)
for (var j=i+1; j<arr.length; j++)
if (arr[i] <= arg && arr[j] <= arg && arr[i] + arr[j] == arg)
sum += i+j;
arr[i] = arr[j] = NaN;
return sum;
console.log( pairwise([1, 1, 0, 2], 2) ) // should return 6
Under the hood:
- Start looping from the element with index (
i
) = 0. - Add a second loop only for the elements which are later in the array. Their index
j
is always higher thani
as we are adding 1 toi
. - If both elements (numbers) are less than or equal to to the
arg
, check if their sum equals to thearg
. This avoids checking the sum if either of the numbers are greater than thearg
. - If the pair has been found then change their values to
NaN
to avoid further checks and duplication.
edited Jun 18 '16 at 13:32
rolfl♦
91.2k13193397
91.2k13193397
answered Jun 18 '16 at 11:02
Piotr BerebeckiPiotr Berebecki
1113
1113
add a comment |
add a comment |
$begingroup$
Old forum but wanted to contribute an ES6 solution
function pairwise(arr, arg)
let sum=0;
// ES6
for(let i in arr)
for(let j in arr)
if(i!=j)
if ((arr[i]+arr[j]) === arg)
sum += (Number(i)+Number(j));
arr[i] = arr[j] = arg+1;
return sum;
pairwise([1, 4, 2, 3, 0, 5], 7)
New contributor
$endgroup$
add a comment |
$begingroup$
Old forum but wanted to contribute an ES6 solution
function pairwise(arr, arg)
let sum=0;
// ES6
for(let i in arr)
for(let j in arr)
if(i!=j)
if ((arr[i]+arr[j]) === arg)
sum += (Number(i)+Number(j));
arr[i] = arr[j] = arg+1;
return sum;
pairwise([1, 4, 2, 3, 0, 5], 7)
New contributor
$endgroup$
add a comment |
$begingroup$
Old forum but wanted to contribute an ES6 solution
function pairwise(arr, arg)
let sum=0;
// ES6
for(let i in arr)
for(let j in arr)
if(i!=j)
if ((arr[i]+arr[j]) === arg)
sum += (Number(i)+Number(j));
arr[i] = arr[j] = arg+1;
return sum;
pairwise([1, 4, 2, 3, 0, 5], 7)
New contributor
$endgroup$
Old forum but wanted to contribute an ES6 solution
function pairwise(arr, arg)
let sum=0;
// ES6
for(let i in arr)
for(let j in arr)
if(i!=j)
if ((arr[i]+arr[j]) === arg)
sum += (Number(i)+Number(j));
arr[i] = arr[j] = arg+1;
return sum;
pairwise([1, 4, 2, 3, 0, 5], 7)
New contributor
New contributor
answered 21 mins ago
RobertRobert
1
1
New contributor
New contributor
add a comment |
add a comment |
Thanks for contributing an answer to Code Review Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
Use MathJax to format equations. MathJax reference.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f98448%2ffree-code-camp-pairwise%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
$begingroup$
Shouldn't the first one return a 4? The instruction did say "If multiple sums are possible, return the smallest sum." and nothing about when multiple sums can be added together or not.
$endgroup$
– Joseph
Jul 30 '15 at 17:04