Explanation:
Basically while the second argument is not true, you will have to remove the first element from the left of the array that was passed as the first argument.
Hint: 1
You can use Array.prototype.shift()
or filter that you should be more familiar with to solve this problem in a few lines of code.
Hint: 2
Shift returns the element that was removed which we don't really need, all we need is the modified array that is left.
Hint: 3
If you still can't figure out how to solve it with shift, then try solving it with filter, and check how filter works, if you become familiar with it, then you can make the code with shift.
Spoiler Alert!
Solution ahead!
Code Solution 1:
function drop(arr, func) {
// Drop them elements.
var times = arr.length;
for (var i = 0; i < times; i++) {
if (func(arr[0])) {
break;
} else {
arr.shift();
}
}
return arr;
}
drop([1, 2, 3], function(n) {return n < 3; });
Code Explanation:
- Create a for loop to check each element.
- Then check for the function given if true then stop, otherwise remove that element.
- return the array.
Code Solution 2:
function drop(arr, func) {
return arr.slice(arr.findIndex(func) >= 0 ? arr.findIndex(func): arr.length, arr.length);
}
drop([1, 2, 3, 4], function(n) {return n >= 3;});
Code Explanation:
- Use ES6
findIndex()
function to find the index of the element that passes the condition - Slice the array from the found index until the end
- There is one edge case! if the condition is not met against any of the elements 'findIndex' will return
-1
which messes up the input toslice()
. In this case use a simple conditional operator to returnfalse
instead of-1
. And the ternary operator (?:) returns the found index of required elements when the condition istrue
, and the length of the array otherwise so that the return value is an empty array as is instructed. For more info see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Conditional_Operator
Code Solution 3:
function drop(arr, func) {
while(arr.length > 0 && !func(arr[0])) {
arr.shift();
}
return arr;
}
drop([1, 2, 3], function(n) {return n < 3; });
Code Explanation
- Use a while loop with
Array.prototype.shift()
to continue checking and dropping the first element of the array until the function returns true. It also makes sure the array is not empty first to avoid infinite loops. - Return the filtered array.
Credits:
If you found this page useful, you can give thanks by copying and pasting this on the main chat: Thanks @Rafase282 @sabahang for your help with Algorithm: Drop it
NOTE: Please add your username only if you have added any relevant main contents to the wiki page. (Please don't remove any existing usernames.)