SlideShare a Scribd company logo
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

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

Automobile Management System Project Report.pdf
Automobile Management System Project Report.pdfAutomobile Management System Project Report.pdf
Automobile Management System Project Report.pdfKamal Acharya
 
Arduino based vehicle speed tracker project
Arduino based vehicle speed tracker projectArduino based vehicle speed tracker project
Arduino based vehicle speed tracker projectRased Khan
 
Event Management System Vb Net Project Report.pdf
Event Management System Vb Net  Project Report.pdfEvent Management System Vb Net  Project Report.pdf
Event Management System Vb Net Project Report.pdfKamal Acharya
 
Cloud-Computing_CSE311_Computer-Networking CSE GUB BD - Shahidul.pptx
Cloud-Computing_CSE311_Computer-Networking CSE GUB BD - Shahidul.pptxCloud-Computing_CSE311_Computer-Networking CSE GUB BD - Shahidul.pptx
Cloud-Computing_CSE311_Computer-Networking CSE GUB BD - Shahidul.pptxMd. Shahidul Islam Prodhan
 
ONLINE VEHICLE RENTAL SYSTEM PROJECT REPORT.pdf
ONLINE VEHICLE RENTAL SYSTEM PROJECT REPORT.pdfONLINE VEHICLE RENTAL SYSTEM PROJECT REPORT.pdf
ONLINE VEHICLE RENTAL SYSTEM PROJECT REPORT.pdfKamal Acharya
 
Top 13 Famous Civil Engineering Scientist
Top 13 Famous Civil Engineering ScientistTop 13 Famous Civil Engineering Scientist
Top 13 Famous Civil Engineering Scientistgettygaming1
 
Courier management system project report.pdf
Courier management system project report.pdfCourier management system project report.pdf
Courier management system project report.pdfKamal Acharya
 
Fruit shop management system project report.pdf
Fruit shop management system project report.pdfFruit shop management system project report.pdf
Fruit shop management system project report.pdfKamal Acharya
 
2024 DevOps Pro Europe - Growing at the edge
2024 DevOps Pro Europe - Growing at the edge2024 DevOps Pro Europe - Growing at the edge
2024 DevOps Pro Europe - Growing at the edgePaco Orozco
 
Democratizing Fuzzing at Scale by Abhishek Arya
Democratizing Fuzzing at Scale by Abhishek AryaDemocratizing Fuzzing at Scale by Abhishek Arya
Democratizing Fuzzing at Scale by Abhishek Aryaabh.arya
 
KIT-601 Lecture Notes-UNIT-3.pdf Mining Data Stream
KIT-601 Lecture Notes-UNIT-3.pdf Mining Data StreamKIT-601 Lecture Notes-UNIT-3.pdf Mining Data Stream
KIT-601 Lecture Notes-UNIT-3.pdf Mining Data StreamDr. Radhey Shyam
 
Immunizing Image Classifiers Against Localized Adversary Attacks
Immunizing Image Classifiers Against Localized Adversary AttacksImmunizing Image Classifiers Against Localized Adversary Attacks
Immunizing Image Classifiers Against Localized Adversary Attacksgerogepatton
 
ENERGY STORAGE DEVICES INTRODUCTION UNIT-I
ENERGY STORAGE DEVICES  INTRODUCTION UNIT-IENERGY STORAGE DEVICES  INTRODUCTION UNIT-I
ENERGY STORAGE DEVICES INTRODUCTION UNIT-IVigneshvaranMech
 
CFD Simulation of By-pass Flow in a HRSG module by R&R Consult.pptx
CFD Simulation of By-pass Flow in a HRSG module by R&R Consult.pptxCFD Simulation of By-pass Flow in a HRSG module by R&R Consult.pptx
CFD Simulation of By-pass Flow in a HRSG module by R&R Consult.pptxR&R Consult
 
IT-601 Lecture Notes-UNIT-2.pdf Data Analysis
IT-601 Lecture Notes-UNIT-2.pdf Data AnalysisIT-601 Lecture Notes-UNIT-2.pdf Data Analysis
IT-601 Lecture Notes-UNIT-2.pdf Data AnalysisDr. Radhey Shyam
 
Halogenation process of chemical process industries
Halogenation process of chemical process industriesHalogenation process of chemical process industries
Halogenation process of chemical process industriesMuhammadTufail242431
 
Hall booking system project report .pdf
Hall booking system project report  .pdfHall booking system project report  .pdf
Hall booking system project report .pdfKamal Acharya
 
Online blood donation management system project.pdf
Online blood donation management system project.pdfOnline blood donation management system project.pdf
Online blood donation management system project.pdfKamal Acharya
 
Quality defects in TMT Bars, Possible causes and Potential Solutions.
Quality defects in TMT Bars, Possible causes and Potential Solutions.Quality defects in TMT Bars, Possible causes and Potential Solutions.
Quality defects in TMT Bars, Possible causes and Potential Solutions.PrashantGoswami42
 
fundamentals of drawing and isometric and orthographic projection
fundamentals of drawing and isometric and orthographic projectionfundamentals of drawing and isometric and orthographic projection
fundamentals of drawing and isometric and orthographic projectionjeevanprasad8
 

Recently uploaded (20)

Automobile Management System Project Report.pdf
Automobile Management System Project Report.pdfAutomobile Management System Project Report.pdf
Automobile Management System Project Report.pdf
 
Arduino based vehicle speed tracker project
Arduino based vehicle speed tracker projectArduino based vehicle speed tracker project
Arduino based vehicle speed tracker project
 
Event Management System Vb Net Project Report.pdf
Event Management System Vb Net  Project Report.pdfEvent Management System Vb Net  Project Report.pdf
Event Management System Vb Net Project Report.pdf
 
Cloud-Computing_CSE311_Computer-Networking CSE GUB BD - Shahidul.pptx
Cloud-Computing_CSE311_Computer-Networking CSE GUB BD - Shahidul.pptxCloud-Computing_CSE311_Computer-Networking CSE GUB BD - Shahidul.pptx
Cloud-Computing_CSE311_Computer-Networking CSE GUB BD - Shahidul.pptx
 
ONLINE VEHICLE RENTAL SYSTEM PROJECT REPORT.pdf
ONLINE VEHICLE RENTAL SYSTEM PROJECT REPORT.pdfONLINE VEHICLE RENTAL SYSTEM PROJECT REPORT.pdf
ONLINE VEHICLE RENTAL SYSTEM PROJECT REPORT.pdf
 
Top 13 Famous Civil Engineering Scientist
Top 13 Famous Civil Engineering ScientistTop 13 Famous Civil Engineering Scientist
Top 13 Famous Civil Engineering Scientist
 
Courier management system project report.pdf
Courier management system project report.pdfCourier management system project report.pdf
Courier management system project report.pdf
 
Fruit shop management system project report.pdf
Fruit shop management system project report.pdfFruit shop management system project report.pdf
Fruit shop management system project report.pdf
 
2024 DevOps Pro Europe - Growing at the edge
2024 DevOps Pro Europe - Growing at the edge2024 DevOps Pro Europe - Growing at the edge
2024 DevOps Pro Europe - Growing at the edge
 
Democratizing Fuzzing at Scale by Abhishek Arya
Democratizing Fuzzing at Scale by Abhishek AryaDemocratizing Fuzzing at Scale by Abhishek Arya
Democratizing Fuzzing at Scale by Abhishek Arya
 
KIT-601 Lecture Notes-UNIT-3.pdf Mining Data Stream
KIT-601 Lecture Notes-UNIT-3.pdf Mining Data StreamKIT-601 Lecture Notes-UNIT-3.pdf Mining Data Stream
KIT-601 Lecture Notes-UNIT-3.pdf Mining Data Stream
 
Immunizing Image Classifiers Against Localized Adversary Attacks
Immunizing Image Classifiers Against Localized Adversary AttacksImmunizing Image Classifiers Against Localized Adversary Attacks
Immunizing Image Classifiers Against Localized Adversary Attacks
 
ENERGY STORAGE DEVICES INTRODUCTION UNIT-I
ENERGY STORAGE DEVICES  INTRODUCTION UNIT-IENERGY STORAGE DEVICES  INTRODUCTION UNIT-I
ENERGY STORAGE DEVICES INTRODUCTION UNIT-I
 
CFD Simulation of By-pass Flow in a HRSG module by R&R Consult.pptx
CFD Simulation of By-pass Flow in a HRSG module by R&R Consult.pptxCFD Simulation of By-pass Flow in a HRSG module by R&R Consult.pptx
CFD Simulation of By-pass Flow in a HRSG module by R&R Consult.pptx
 
IT-601 Lecture Notes-UNIT-2.pdf Data Analysis
IT-601 Lecture Notes-UNIT-2.pdf Data AnalysisIT-601 Lecture Notes-UNIT-2.pdf Data Analysis
IT-601 Lecture Notes-UNIT-2.pdf Data Analysis
 
Halogenation process of chemical process industries
Halogenation process of chemical process industriesHalogenation process of chemical process industries
Halogenation process of chemical process industries
 
Hall booking system project report .pdf
Hall booking system project report  .pdfHall booking system project report  .pdf
Hall booking system project report .pdf
 
Online blood donation management system project.pdf
Online blood donation management system project.pdfOnline blood donation management system project.pdf
Online blood donation management system project.pdf
 
Quality defects in TMT Bars, Possible causes and Potential Solutions.
Quality defects in TMT Bars, Possible causes and Potential Solutions.Quality defects in TMT Bars, Possible causes and Potential Solutions.
Quality defects in TMT Bars, Possible causes and Potential Solutions.
 
fundamentals of drawing and isometric and orthographic projection
fundamentals of drawing and isometric and orthographic projectionfundamentals of drawing and isometric and orthographic projection
fundamentals of drawing and isometric and orthographic projection
 

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.