SlideShare a Scribd company logo
1 of 24
1
Lecture 9: Stack and Queue
What is a Stack
• Stack of Books
2
Stacks
• What is a Stack?
– A stack is a data structure of ordered items such
that items can be inserted and removed only at
one end.
3
4
Stacks
• What can we do with a stack?
– push - place an item on the stack
– peek - Look at the item on top of the stack,
but do not remove it
– pop - Look at the item on top of the stack
and remove it
5
Stacks
• A stack is a LIFO (Last-In/First-Out) data
structure
• A stack is sometimes also called a
pushdown store.
• What are some applications of stacks?
– Program execution
– Parsing
– Evaluating postfix expressions
6
Stacks
• Problem:
– What happens if we try to pop an item off the
stack when the stack is empty?
• This is called a stack underflow. The pop method
needs some way of telling us that this has happened.
In java we use the java.util.EmptyStackException
Interface IStack
Interface Istack {
boolean empty();
void push(char c);
char pop();
char peek();
}
Using a IStack
• A balance of braces.
– (()) balanced braces
– ()(()()))) not balanced braces
• How can you use Istack to check a brace is
balanced or not?
When you implement the above
requirement, you ignore the
implementation details of Istack.
9
Implementing a Stack
• There are two ways we can implement a
stack:
– Using an array
– Using a linked list
10
Implementing a Stack
• Implementing a stack using an array is
fairly easy.
– The bottom of the stack is at data[0]
– The top of the stack is at data[numItems-1]
– push onto the stack at data[numItems]
– pop off of the stack at data[numItems-1]
11
Implementing a Stack
• Implementing a stack using a linked list
isn’t that bad either…
– Store the items in the stack in a linked list
– The top of the stack is the head node, the
bottom of the stack is the end of the list
– push by adding to the front of the list
– pop by removing from the front of the list
12
Reversing a Word
• We can use a stack to reverse the letters in a
word.
• How?
13
Reversing a Word
• Read each letter in the word and push it
onto the stack
• When you reach the end of the word, pop
the letters off the stack and print them out.
What is a Queue?
14
15
Queues
• What is a queue?
– A data structure of ordered items such that
items can be inserted only at one end and
removed at the other end.
• Example
– A line at the supermarket
16
Queues
• What can we do with a queue?
– Enqueue - Add an item to the queue
– Dequeue - Remove an item from the queue
• These ops are also called insert and getFront
in order to simplify things.
Queues
• A queue is called a FIFO (First in-First out)
data structure.
• What are some applications of queues?
– Round-robin scheduling in processors
– Input/Output processing
– Queueing of packets for delivery in networks
17
18
Implementing a Queue
• Just like a stack, we can implementing a
queue in two ways:
– Using an array
– Using a linked list
19
Implementing a Queue
• Using an array to implement a queue is
significantly harder than using an array to
implement a stack. Why?
– Unlike a stack, where we add and remove at the
same end, in a queue we add to one end and
remove from the other.
20
Implementing a Queue
• There are two options for implementing a
queue using an array:
• Option 1:
– Enqueue at data[0] and shift all of the rest of
the items in the array down to make room.
– Dequeue from data[numItems-1]
21
Implementing a Queue
• Option 2
– Enqueue at data[rear+1]
– Dequeue at data[front]
– The rear variable always contains the index of
the last item in the queue.
– The front variable always contains the index of
the first item in the queue.
– When we reach the end of the array, wrap
around to the front again.
22
Implementing a Queue
// option 2 sketch of insert
insert(Object item) {
if(manyItems == 0) front = rear = 0;
else rear = (rear + 1) mod size;
data[rear] = item;
manyItems++;
}
23
Implementing a Queue
// option 2 sketch of getFront
Object getFront() {
answer = data[front];
front = (front + 1) mod size;
manyItems--;
return answer
}
24
Implementing a Queue
• Implementing a queue using a linked list is
still easy:
– Front of the queue is stored as the head node of
the linked list, rear of the queue is stored as the
tail node.
– Enqueue by adding to the end of the list
– Dequeue by removing from the front of the list.

More Related Content

Similar to StackQueue.ppt

Queue ADT for data structure for computer
Queue ADT for data structure for computerQueue ADT for data structure for computer
Queue ADT for data structure for computer
abinathsabi
 

Similar to StackQueue.ppt (20)

Stack and Queue.pptx
Stack and Queue.pptxStack and Queue.pptx
Stack and Queue.pptx
 
Difference between stack and queue
Difference between stack and queueDifference between stack and queue
Difference between stack and queue
 
STACK.pptx
STACK.pptxSTACK.pptx
STACK.pptx
 
Stacks and Queue,Concept of Stack,LIFO,Fifo,
Stacks and Queue,Concept of Stack,LIFO,Fifo,Stacks and Queue,Concept of Stack,LIFO,Fifo,
Stacks and Queue,Concept of Stack,LIFO,Fifo,
 
Queues
Queues Queues
Queues
 
VCE Unit 03vv.pptx
VCE Unit 03vv.pptxVCE Unit 03vv.pptx
VCE Unit 03vv.pptx
 
Stacks
StacksStacks
Stacks
 
Stacks
StacksStacks
Stacks
 
2.1 STACK & QUEUE ADTS
2.1 STACK & QUEUE ADTS2.1 STACK & QUEUE ADTS
2.1 STACK & QUEUE ADTS
 
Data structures
Data structuresData structures
Data structures
 
Data Structure - Stack.pptx
Data Structure - Stack.pptxData Structure - Stack.pptx
Data Structure - Stack.pptx
 
STACKS AND QUEUES.pptx
STACKS AND QUEUES.pptxSTACKS AND QUEUES.pptx
STACKS AND QUEUES.pptx
 
STACKS AND QUEUES.pptx
STACKS AND QUEUES.pptxSTACKS AND QUEUES.pptx
STACKS AND QUEUES.pptx
 
Queue ADT for data structure for computer
Queue ADT for data structure for computerQueue ADT for data structure for computer
Queue ADT for data structure for computer
 
Data structure.pdf
Data structure.pdfData structure.pdf
Data structure.pdf
 
Stack and its Applications : Data Structures ADT
Stack and its Applications : Data Structures ADTStack and its Applications : Data Structures ADT
Stack and its Applications : Data Structures ADT
 
Queue AS an ADT (Abstract Data Type)
Queue AS an ADT (Abstract Data Type)Queue AS an ADT (Abstract Data Type)
Queue AS an ADT (Abstract Data Type)
 
stack.pptx
stack.pptxstack.pptx
stack.pptx
 
Data Structures
Data StructuresData Structures
Data Structures
 
What is Stack, Its Operations, Queue, Circular Queue, Priority Queue
What is Stack, Its Operations, Queue, Circular Queue, Priority QueueWhat is Stack, Its Operations, Queue, Circular Queue, Priority Queue
What is Stack, Its Operations, Queue, Circular Queue, Priority Queue
 

Recently uploaded

Hospital management system project report.pdf
Hospital management system project report.pdfHospital management system project report.pdf
Hospital management system project report.pdf
Kamal Acharya
 

Recently uploaded (20)

HOA1&2 - Module 3 - PREHISTORCI ARCHITECTURE OF KERALA.pptx
HOA1&2 - Module 3 - PREHISTORCI ARCHITECTURE OF KERALA.pptxHOA1&2 - Module 3 - PREHISTORCI ARCHITECTURE OF KERALA.pptx
HOA1&2 - Module 3 - PREHISTORCI ARCHITECTURE OF KERALA.pptx
 
Linux Systems Programming: Inter Process Communication (IPC) using Pipes
Linux Systems Programming: Inter Process Communication (IPC) using PipesLinux Systems Programming: Inter Process Communication (IPC) using Pipes
Linux Systems Programming: Inter Process Communication (IPC) using Pipes
 
Unit 4_Part 1 CSE2001 Exception Handling and Function Template and Class Temp...
Unit 4_Part 1 CSE2001 Exception Handling and Function Template and Class Temp...Unit 4_Part 1 CSE2001 Exception Handling and Function Template and Class Temp...
Unit 4_Part 1 CSE2001 Exception Handling and Function Template and Class Temp...
 
Online electricity billing project report..pdf
Online electricity billing project report..pdfOnline electricity billing project report..pdf
Online electricity billing project report..pdf
 
Thermal Engineering-R & A / C - unit - V
Thermal Engineering-R & A / C - unit - VThermal Engineering-R & A / C - unit - V
Thermal Engineering-R & A / C - unit - V
 
Jaipur ❤CALL GIRL 0000000000❤CALL GIRLS IN Jaipur ESCORT SERVICE❤CALL GIRL IN...
Jaipur ❤CALL GIRL 0000000000❤CALL GIRLS IN Jaipur ESCORT SERVICE❤CALL GIRL IN...Jaipur ❤CALL GIRL 0000000000❤CALL GIRLS IN Jaipur ESCORT SERVICE❤CALL GIRL IN...
Jaipur ❤CALL GIRL 0000000000❤CALL GIRLS IN Jaipur ESCORT SERVICE❤CALL GIRL IN...
 
Tamil Call Girls Bhayandar WhatsApp +91-9930687706, Best Service
Tamil Call Girls Bhayandar WhatsApp +91-9930687706, Best ServiceTamil Call Girls Bhayandar WhatsApp +91-9930687706, Best Service
Tamil Call Girls Bhayandar WhatsApp +91-9930687706, Best Service
 
457503602-5-Gas-Well-Testing-and-Analysis-pptx.pptx
457503602-5-Gas-Well-Testing-and-Analysis-pptx.pptx457503602-5-Gas-Well-Testing-and-Analysis-pptx.pptx
457503602-5-Gas-Well-Testing-and-Analysis-pptx.pptx
 
FEA Based Level 3 Assessment of Deformed Tanks with Fluid Induced Loads
FEA Based Level 3 Assessment of Deformed Tanks with Fluid Induced LoadsFEA Based Level 3 Assessment of Deformed Tanks with Fluid Induced Loads
FEA Based Level 3 Assessment of Deformed Tanks with Fluid Induced Loads
 
Hospital management system project report.pdf
Hospital management system project report.pdfHospital management system project report.pdf
Hospital management system project report.pdf
 
Orlando’s Arnold Palmer Hospital Layout Strategy-1.pptx
Orlando’s Arnold Palmer Hospital Layout Strategy-1.pptxOrlando’s Arnold Palmer Hospital Layout Strategy-1.pptx
Orlando’s Arnold Palmer Hospital Layout Strategy-1.pptx
 
Computer Networks Basics of Network Devices
Computer Networks  Basics of Network DevicesComputer Networks  Basics of Network Devices
Computer Networks Basics of Network Devices
 
NO1 Top No1 Amil Baba In Azad Kashmir, Kashmir Black Magic Specialist Expert ...
NO1 Top No1 Amil Baba In Azad Kashmir, Kashmir Black Magic Specialist Expert ...NO1 Top No1 Amil Baba In Azad Kashmir, Kashmir Black Magic Specialist Expert ...
NO1 Top No1 Amil Baba In Azad Kashmir, Kashmir Black Magic Specialist Expert ...
 
COST-EFFETIVE and Energy Efficient BUILDINGS ptx
COST-EFFETIVE  and Energy Efficient BUILDINGS ptxCOST-EFFETIVE  and Energy Efficient BUILDINGS ptx
COST-EFFETIVE and Energy Efficient BUILDINGS ptx
 
Ghuma $ Russian Call Girls Ahmedabad ₹7.5k Pick Up & Drop With Cash Payment 8...
Ghuma $ Russian Call Girls Ahmedabad ₹7.5k Pick Up & Drop With Cash Payment 8...Ghuma $ Russian Call Girls Ahmedabad ₹7.5k Pick Up & Drop With Cash Payment 8...
Ghuma $ Russian Call Girls Ahmedabad ₹7.5k Pick Up & Drop With Cash Payment 8...
 
Thermal Engineering Unit - I & II . ppt
Thermal Engineering  Unit - I & II . pptThermal Engineering  Unit - I & II . ppt
Thermal Engineering Unit - I & II . ppt
 
fitting shop and tools used in fitting shop .ppt
fitting shop and tools used in fitting shop .pptfitting shop and tools used in fitting shop .ppt
fitting shop and tools used in fitting shop .ppt
 
Computer Graphics Introduction To Curves
Computer Graphics Introduction To CurvesComputer Graphics Introduction To Curves
Computer Graphics Introduction To Curves
 
UNIT 4 PTRP final Convergence in probability.pptx
UNIT 4 PTRP final Convergence in probability.pptxUNIT 4 PTRP final Convergence in probability.pptx
UNIT 4 PTRP final Convergence in probability.pptx
 
AIRCANVAS[1].pdf mini project for btech students
AIRCANVAS[1].pdf mini project for btech studentsAIRCANVAS[1].pdf mini project for btech students
AIRCANVAS[1].pdf mini project for btech students
 

StackQueue.ppt

  • 1. 1 Lecture 9: Stack and Queue
  • 2. What is a Stack • Stack of Books 2
  • 3. Stacks • What is a Stack? – A stack is a data structure of ordered items such that items can be inserted and removed only at one end. 3
  • 4. 4 Stacks • What can we do with a stack? – push - place an item on the stack – peek - Look at the item on top of the stack, but do not remove it – pop - Look at the item on top of the stack and remove it
  • 5. 5 Stacks • A stack is a LIFO (Last-In/First-Out) data structure • A stack is sometimes also called a pushdown store. • What are some applications of stacks? – Program execution – Parsing – Evaluating postfix expressions
  • 6. 6 Stacks • Problem: – What happens if we try to pop an item off the stack when the stack is empty? • This is called a stack underflow. The pop method needs some way of telling us that this has happened. In java we use the java.util.EmptyStackException
  • 7. Interface IStack Interface Istack { boolean empty(); void push(char c); char pop(); char peek(); }
  • 8. Using a IStack • A balance of braces. – (()) balanced braces – ()(()()))) not balanced braces • How can you use Istack to check a brace is balanced or not? When you implement the above requirement, you ignore the implementation details of Istack.
  • 9. 9 Implementing a Stack • There are two ways we can implement a stack: – Using an array – Using a linked list
  • 10. 10 Implementing a Stack • Implementing a stack using an array is fairly easy. – The bottom of the stack is at data[0] – The top of the stack is at data[numItems-1] – push onto the stack at data[numItems] – pop off of the stack at data[numItems-1]
  • 11. 11 Implementing a Stack • Implementing a stack using a linked list isn’t that bad either… – Store the items in the stack in a linked list – The top of the stack is the head node, the bottom of the stack is the end of the list – push by adding to the front of the list – pop by removing from the front of the list
  • 12. 12 Reversing a Word • We can use a stack to reverse the letters in a word. • How?
  • 13. 13 Reversing a Word • Read each letter in the word and push it onto the stack • When you reach the end of the word, pop the letters off the stack and print them out.
  • 14. What is a Queue? 14
  • 15. 15 Queues • What is a queue? – A data structure of ordered items such that items can be inserted only at one end and removed at the other end. • Example – A line at the supermarket
  • 16. 16 Queues • What can we do with a queue? – Enqueue - Add an item to the queue – Dequeue - Remove an item from the queue • These ops are also called insert and getFront in order to simplify things.
  • 17. Queues • A queue is called a FIFO (First in-First out) data structure. • What are some applications of queues? – Round-robin scheduling in processors – Input/Output processing – Queueing of packets for delivery in networks 17
  • 18. 18 Implementing a Queue • Just like a stack, we can implementing a queue in two ways: – Using an array – Using a linked list
  • 19. 19 Implementing a Queue • Using an array to implement a queue is significantly harder than using an array to implement a stack. Why? – Unlike a stack, where we add and remove at the same end, in a queue we add to one end and remove from the other.
  • 20. 20 Implementing a Queue • There are two options for implementing a queue using an array: • Option 1: – Enqueue at data[0] and shift all of the rest of the items in the array down to make room. – Dequeue from data[numItems-1]
  • 21. 21 Implementing a Queue • Option 2 – Enqueue at data[rear+1] – Dequeue at data[front] – The rear variable always contains the index of the last item in the queue. – The front variable always contains the index of the first item in the queue. – When we reach the end of the array, wrap around to the front again.
  • 22. 22 Implementing a Queue // option 2 sketch of insert insert(Object item) { if(manyItems == 0) front = rear = 0; else rear = (rear + 1) mod size; data[rear] = item; manyItems++; }
  • 23. 23 Implementing a Queue // option 2 sketch of getFront Object getFront() { answer = data[front]; front = (front + 1) mod size; manyItems--; return answer }
  • 24. 24 Implementing a Queue • Implementing a queue using a linked list is still easy: – Front of the queue is stored as the head node of the linked list, rear of the queue is stored as the tail node. – Enqueue by adding to the end of the list – Dequeue by removing from the front of the list.