Deque deletion
Problem Statement - link #
Given a Deque deq of size N containing non-negative integers.
Complete below functions depending type of query as mentioned and provided to you (indexing starts from 0):
- eraseAt(X): this function should remove the element from specified position- Xin deque.
- eraseInRange(start, end): this function should remove the elements in range start (inclusive), end (exclusive) specified in the argument of the function. Note: If start is equal to end then simply return.
- eraseAll(): remove all the elements from the deque.
Your Task: 
 Complete the functions eraseAt() which takes dequeue and a postion as input parameters, eraseInRange() which takes dequeue, start(inclusive) and end(exclusive) as input parameters and eraseAll() which takes a dequeue as input parameter.
Expected Time Complexity: O(N) 
 Expected Auxiliary Space: O(1)
Examples #
Example 1:
Input:
5
1 2 4 5 6
1 2
Output: 
1 2 5 6 
Explanation: 
Here the query type is 1 
and the position is 2. So we remove 
element at position 2. The element at 
position 2 is 1 2 4 5 6. So, we remove 
4 and get 1 2 5 6.
Example 2:
Input: 
4
1 2 3 4
2 1 3
Output: 
1 4 
Explanation: 
Here the query type is 2 
and the range is [1, 3). So we need to 
delete 1 2 3 4. Remember that end is 
exclusive. So the updated dequeue is 1 4.
Example 3:
Input:
3
1 2 3
3
Output: 
Empty
Explanation: 
Here the query is of type 3 
so we remove all the elements of dequeue.
Constraints #
- 1 <= N <= 10^5
Solutions #
//Function to erase the element from specified position X in deque.
void eraseAt(deque <int> &deq, int X)
{
    // your code here
    deq.erase(deq.begin()+X);
}
//Function to erase the elements in range start (inclusive), end (exclusive).
void eraseInRange(deque<int> &deq, int start, int end)
{
    // your code here
    deq.erase(deq.begin()+start,deq.begin()+end);
}
//Function to erase all the elements in the deque.
void eraseAll(deque<int> &deq)
{
   // your code here
   deq.clear();
}