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.

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

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.

Expert Solution
steps

Step by step

Solved in 3 steps

Blurred answer
Knowledge Booster
Stack
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
  • SEE MORE QUESTIONS
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education