Problem 1: Generalized queue. Design a data structure that supports the following operations for a generalized queue: (i) Find(i) which returns the i-th item from the queue. (ii) InsertFirst(x) which inserts item x at the front of the queue. (iii) InsertLast(x) which inserts item x to the front of the queue. (iv) Delete(i) which removes the i-th item from the queue. Here is a simple example: Initialize Q to be an empty generalized queue. Calling InsertFirst(A) on Q results in Q = [A]. Calling InsertFirst(B) on Q results in Q = [B, A]. Calling InsertLast(C) on Q results in Q = [B, A, C]. Calling InsertLast(D) on Q results in Q = [B, A, C, D]. Calling InsertFirst(E) on Q results in Q = [E, B, A, C, D]. Calling InsertFirst(F) on Q results in Q = [F, E, B, A, C, D]. Calling InsertLast(G) on Q results in Q = [F, E, B, A, C, D, G]. Calling Find(2) on Q returns E. Calling Delete(2) on Q results in Q = [F, B, A, C, D, G]. Calling Find(2) on Q returns B. Your data structure should implement all operations in O(log n), where n is the number of elements in the data structure.
Problem 1: Generalized queue. Design a data structure that supports the following
operations for a generalized queue:
(i) Find(i) which returns the i-th item from the queue.
(ii) InsertFirst(x) which inserts item x at the front of the queue.
(iii) InsertLast(x) which inserts item x to the front of the queue.
(iv) Delete(i) which removes the i-th item from the queue.
Here is a simple example:
Initialize Q to be an empty generalized queue.
Calling InsertFirst(A) on Q results in Q = [A].
Calling InsertFirst(B) on Q results in Q = [B, A].
Calling InsertLast(C) on Q results in Q = [B, A, C].
Calling InsertLast(D) on Q results in Q = [B, A, C, D].
Calling InsertFirst(E) on Q results in Q = [E, B, A, C, D].
Calling InsertFirst(F) on Q results in Q = [F, E, B, A, C, D].
Calling InsertLast(G) on Q results in Q = [F, E, B, A, C, D, G].
Calling Find(2) on Q returns E.
Calling Delete(2) on Q results in Q = [F, B, A, C, D, G].
Calling Find(2) on Q returns B.
Your data structure should implement all operations in O(log n), where n is the number
of elements in the data structure.
![](/static/compass_v2/shared-icons/check-mark.png)
Step by step
Solved in 3 steps
![Blurred answer](/static/compass_v2/solution-images/blurred-answer.jpg)
![Database System Concepts](https://www.bartleby.com/isbn_cover_images/9780078022159/9780078022159_smallCoverImage.jpg)
![Starting Out with Python (4th Edition)](https://www.bartleby.com/isbn_cover_images/9780134444321/9780134444321_smallCoverImage.gif)
![Digital Fundamentals (11th Edition)](https://www.bartleby.com/isbn_cover_images/9780132737968/9780132737968_smallCoverImage.gif)
![Database System Concepts](https://www.bartleby.com/isbn_cover_images/9780078022159/9780078022159_smallCoverImage.jpg)
![Starting Out with Python (4th Edition)](https://www.bartleby.com/isbn_cover_images/9780134444321/9780134444321_smallCoverImage.gif)
![Digital Fundamentals (11th Edition)](https://www.bartleby.com/isbn_cover_images/9780132737968/9780132737968_smallCoverImage.gif)
![C How to Program (8th Edition)](https://www.bartleby.com/isbn_cover_images/9780133976892/9780133976892_smallCoverImage.gif)
![Database Systems: Design, Implementation, & Manag…](https://www.bartleby.com/isbn_cover_images/9781337627900/9781337627900_smallCoverImage.gif)
![Programmable Logic Controllers](https://www.bartleby.com/isbn_cover_images/9780073373843/9780073373843_smallCoverImage.gif)