--- id: 587d8251367417b2b2512c65 title: Remove Elements from a Linked List by Index challengeType: 1 --- ## Description
Before we move on to another data structure, let's get a couple of last bits of practice with linked lists. Let's write a removeAt method that removes the element at a given index. The method should be called removeAt(index). To remove an element at a certain index, we'll need to keep a running count of each node as we move along the linked list. A common technique used to iterate through the elements of a linked list involves a 'runner', or sentinel, that 'points' at the nodes that your code is comparing. In our case, starting at the head of our list, we start with a currentIndex variable that starts at 0. The currentIndex should increment by one for each node we pass. Just like our remove(element) method, we need to be careful not to orphan the rest of our list when we remove the node in our removeAt(index) method. We keep our nodes contiguous by making sure that the node that has reference to the removed node has a reference to the next node.
## Instructions
Write a removeAt(index) method that removes and returns a node at a given index. The method should return null if the given index is either negative, or greater than or equal to the length of the linked list. Note Remember to keep count of the currentIndex.
## Tests
```yml tests: - text: Your LinkedList class should have a removeAt method. testString: assert((function(){var test = new LinkedList(); return (typeof test.removeAt === 'function')}()), 'Your LinkedList class should have a removeAt method.'); - text: Your removeAt method should reduce the length of the linked list testString: assert((function(){var test = new LinkedList(); test.add('cat'); test.add('dog'); test.add('kitten'); test.removeAt(1); return test.size() === 2}()), 'Your removeAt method should reduce the length of the linked list'); - text: Your removeAt method should also return the element of the removed node. testString: assert((function(){var test = new LinkedList(); test.add('cat'); test.add('dog'); test.add('kitten'); return test.removeAt(1) === 'dog'}()), 'Your removeAt method should also return the element of the removed node.'); - text: Your removeAt method should also return null if the given index is less than 0 testString: assert((function(){var test = new LinkedList(); test.add('cat'); test.add('dog'); test.add('kitten'); return (test.removeAt(-1) === null)}()), 'Your removeAt method should also return null if the given index is less than 0'); - text: Your removeAt method should also return null if the given index is equal or more than the length of the linked list. testString: assert((function(){var test = new LinkedList(); test.add('cat'); test.add('dog'); test.add('kitten'); return (test.removeAt(3) === null)}()), 'Your removeAt method should also return null if the given index is equal or more than the length of the linked list.'); ```
## Challenge Seed
```js function LinkedList() { var length = 0; var head = null; var Node = function(element){ // {1} this.element = element; this.next = null; }; this.size = function(){ return length; }; this.head = function(){ return head; }; this.add = function(element){ var node = new Node(element); if(head === null){ head = node; } else { currentNode = head; while(currentNode.next){ currentNode = currentNode.next; } currentNode.next = node; } length++; }; this.remove = function(element){ var currentNode = head; var previousNode; if(currentNode.element === element){ head = currentNode.next; } else { while(currentNode.element !== element) { previousNode = currentNode; currentNode = currentNode.next; } previousNode.next = currentNode.next; } length --; }; // Only change code below this line // Only change code above this line } ```
## Solution
```js // solution required ```