DATA STRUCTURE
AND
ALGORITHM
Dr. Irfana Memon
Department of CSE, QUEST
https://sites.google.com/a/quest.edu.pk/dr-irfana-memon/lecture-slides
1
NO TOPIC CLO
01 A General Overview CLO1
02 Introduction to Data Structures and Algorithm CLO1
03 String Processing CLO1
04 Abstract Data Types CLO1
05 Linked list CLO1
06 Stack and Queue CLO1
07 Recursion CLO1
08 Complexity Analysis CLO2
09 Sorting and Searching techniques CLO2
10 Trees CLO2
11 Graph CLO3
12 P & NP CLO3
2
CHAPTER 5
Linked List
Disadvantages of arrays as storage data structures:
slow insertion in ordered array
Fixed size
Linked lists solve some of these problems
Linked lists are general purpose storage data structures.
• A linked list, or one way list, is a linear collection of data elements,
called nodes, where the linear order is given by means of links.
• Each node is divided into two parts:
• The first part contains the information of the element, and
• The second part, called the link field, contains the address of the
next node in the list.
• The link of the last node contains a special value, called the null .
• A link variable – called START which contains the address of the
first node.
• A special case is the list that has no nodes, such a list is called the
null list or empty list and is denoted by the null in the variable
START. nod
e A
data link
Start
node node node
Data Next Data Next Data
Linked list with 3 nodes
• A linked list organizes a collection of data items (elements )
such that elements can easily be added to and deleted from
any position in the list
• Only references To next elements are updated in insertion
and deletion operations
• There is no need to copy or move large blocks of data to
facilitate insertion and deletion of elements
• Lists grow dynamically
INFO LINK
1
START START=3, INFO[3]=45
2 67 5 LINK[3]=2, INFO[2]=67
3
3 45 2 LINK[2]=5, INFO[5]=75
7 LINK[5]=4, INFO[4]=80
4 80
LINK[4]=7, INFO[7]=90
5 75 4
LINK[7]=0, NULL value, So the list has
6 ended
7 90 0
8
• Traversing
• Insert
• Delete
• LIST be a linked list in memory stored in linear arrays INFO and LINK
with START pointing to the first element and NULL indicating the end of
LIST
• We want to traverse LIST in order to process each node exactly once
• Pointer variable PTR points to the node that is currently being
processed
• LINK[PTR] points to the next node to be processed
• Thus update PTR by the assignment
PTR : =LINK[PTR] PTR
START INFO LINK
X
Fig : PTR : = LINK[PTR]
Algorithm 1 : Algorithm Prints the information at each node of
the list.
Algorithm 1 : Algorithm Prints the information at each node of
the list.
PRINT(INFO, LINK, START)
1. Set PTR : =START.
2. Repeat steps 3 and 4 while PTR : ≠ NULL:
3. Write : INFO[PTR].
4. Set PTR : =LINK[PTR].
5. Exit.
Exercise: Write an algorithm and draw flow chart to find the
number NUM of elements in a linked list, must traverse the
list.
Exercise: Write an algorithm and draw flow chart to find the
number NUM of elements in a linked list, must traverse the
list.
1. Set NUM: =0.
2. . Set PTR : =START.
3. Repeat steps 4 and 5 while PTR : ≠ NULL:
4. Set NUM : =NUM+1.
5. Set PTR : =LINK[PTR].
6. Exit.
Memory space can be reused if a node is deleted from a list
i.e deleted node can be made available for future use
The operating system of a computer may periodically collect all the
deleted space on to the free storage list. Any technique which does
this collection called garbage collection
Periodic
Collector
Computer
programs Garbage
(Deleted Space) Sent to
avail
list
Takes
space …
avail list Avail List (Free space)
Overflow:
Sometimes data are inserted into a data structure but there
is no available space.
This situation is called overflow
Example: In linked list overflow occurs when
AVAIL= NULL and
There is an insertion operation
Underflow:
Situation:
Want to delete data from data structure that is empty.
Example: In linked list overflow occurs when
START = NULL and
There is an deletion operation
Possible cases of Insert Node
1. Insert into an empty list
2. Insert in front
3. Insert at back
4. Insert in middle
But, in fact, only need to handle two cases:
1. Insert as the first node (Case 1 and Case 2)
2. Insert in the middle or at the end of the list (Case 3 and
Case 4)
Node N is to be inserted at the start of the linked list
Three pointer fields are changed as follows:
1. START points to the new node N, to which AVAIL previously pointed.
2. AVAIL now point to the second node in the free pool, to which node N
previously pointed.
3. The next pointer field of node N now points to the node, to which START
previously pointed.
START
Node A Node
B
START
(a) Before insertion
Node A Node
B
AVAIL (a) After insertion
Node N Node N
Free storage list
INSLOC(INFO, LINK, START, AVAIL, LOC, ITEM)
1. [OVERFLOW?] If AVAIL=NULL, then print OVERFLOW and
exit
Check for
available memory
INSLOC(INFO, LINK, START, AVAIL, LOC, ITEM)
1. [OVERFLOW?] If AVAIL=NULL, then print OVERFLOW and
exit
Check for
2. Set NEW= AVAIL and AVAIL=LINK[AVAIL] available memory
3. Set INFO[NEW]= ITEM
INSLOC(INFO, LINK, START, AVAIL, LOC, ITEM)
1. [OVERFLOW?] If AVAIL=NULL, then print OVERFLOW and
exit
Check for
2. Set NEW= AVAIL and AVAIL=LINK[AVAIL] available memory
3. Set INFO[NEW]= ITEM
Create a new node
INSLOC(INFO, LINK, START, AVAIL, LOC, ITEM)
1. [OVERFLOW?] If AVAIL=NULL, then print OVERFLOW and
exit
2. Set NEW= AVAIL and AVAIL=LINK[AVAIL]
3. Set INFO[NEW]= ITEM
Insert as first element
4. LINK[NEW]=START
5. START=NEW
6. EXIT
INSLOC(INFO, LINK, START, AVAIL, LOC, ITEM)
1. [OVERFLOW?] If AVAIL=NULL, then print OVERFLOW and
exit
2. Set NEW= AVAIL and AVAIL=LINK[AVAIL]
3. Set INFO[NEW]= ITEM
4. IF LOC = NULL then [Insert as first Node] Insert after
Set LINK[NEW]= START and START=NEW. current Node
LOC
Else: [Insert after node with location LOC]
Set LINK[NEW]= LINK [LOC] and LINK[LOC]= NEW
5. Exit.
FINDA(INFO, LINK, START, ITEM, LOC)
Algorithm: To find the location LOC of the last node in a sorted list
such that INFO[LOC] < ITEM or sets LOC= NULL
FINDA(INFO, LINK, START, ITEM, LOC)
This procedure finds the location LOC of the last node in a sorted
list such that
INFO[LOC] < ITEM or sets LOC= NULL
1. [List Empty?] If START = NULL then:
Set LOC = NULL and return.
FINDA(INFO, LINK, START, ITEM, LOC)
This procedure finds the location LOC of the last node in a sorted list
such that
INFO[LOC] < ITEM or sets LOC= NULL
1. [List Empty?] If START = NULL then:
Set LOC = NULL and return.
2. [special case?] If ITEM < INFO[START], then:
Set LOC = NULL and return.
FINDA(INFO, LINK, START, ITEM, LOC)
This procedure finds the location LOC of the last node in a sorted list
such that
INFO[LOC] < ITEM or sets LOC= NULL
1. [List Empty?] If START = NULL then:
Set LOC = NULL and return.
2. [special case?] If ITEM < INFO[START], then:
Set LOC = NULL and return.
3. Set SAVE=START and PTR = LINK[START] [initialize pointer]
4. Repeat step 5 and 6 while PTR ≠ NULL.
5. If ITEM < INFO[PTR] then:
Set LOC= SAVE and Return.
6. Set SAVE = PTR and PTR= LINK[PTR] [update pointer]
(End of step 4)
7. Set LOC= SAVE
8. Exit.
ITEM must be inserted between nodes A and B so that
INFO(A)<ITEM<=INFO(B)
Traverse the list using a pointer variable PTR
Comparing the ITEM with INFO[PTR] at each node.
Keep track the location of the preceding node by a pointer variable
SAVE, as in fig 5-20
SAVE and PTR are updated by the assignments
SAVE : =PTR and PTR : =LINK[PTR]
START SAVE PTR
Node A Node
B
Algorithm : Write algorithm inserts an item into a sorted linked list.
Algorithm : INSSRT(INFO, LINK, START, AVAIL, ITEM)
This algorithm inserts an item into a sorted linked list.
1. [Use Procedure 5.6 to find the location of the node preceding ITEM]
Call FINDA(INFO, LINK, START, ITEM, LOC).
2. [Use algorithm 5.5 to insert ITEM after the node with location LOC]
Call INSLOC(INFO, LINK, START, AVAIL, LOC, ITEM).
3. Exit
The next pointer field of node-A now points to node-B, where node-N previously pointed
The next pointer field of N now points to the original first node in the free pool, where
AVAIL previously pointed.
AVAIL now points to the deleted node-N
START
Node A Node N Node B
(a) Before deletion
START
After deletion
Node A Node N Node B
AVAIL
Free storage list
DELETE(INFO, LINK, START, AVAIL, ITEM)
Delete a node with the value equal to INFO from the list.
If such a node is found, return its position. Otherwise,
return NULL.
Steps
Find the desirable node (similar to FINDB)
Release the memory occupied by the found node
Set the pointer of the predecessor of the found node to the
successor of the found node
Like INSLOC, there are two special cases
Delete first node
Delete the node in middle or at the end of the list
DELETE(INFO, LINK, START, AVAIL, ITEM)
1. Call FINDB(INFO, LINK, START, ITEM, LOC, LOCP)
Try to find the node with
its value equal to N
DELETE(INFO, LINK, START, AVAIL, ITEM)
1. Call FINDB(INFO, LINK, START, ITEM, LOC, LOCP)
2. IF LOC = NULL then: ITEM not in the list and exit.
3. [Delete node]
IF LOCP = NULL then:
Set START= = LINK[START] [Delete first node]
Else: START LOC
Set LINK[LOCP] = LINK [LOC]
4. Return deleted node to the AVAIL list
Set LINK[LOC] = AVAIL and AVAIL = LOC
5. Exit.
DELETE(INFO, LINK, START, AVAIL, ITEM)
1. Call FINDB(INFO, LINK, START, ITEM, LOC, LOCP)
2. IF LOC = NULL then: ITEM not in the list and exit.
3. [Delete node]
IF LOCP = NULL then:
Set START= = LINK[START] [Delete first node]
Else:
Set LINK[LOCP] = LINK [LOC]
LOCP LOC
4. Return deleted node to the AVAIL list
Set LINK[LOC] = AVAIL and AVAIL = LOC
5. Exit.
FINDB(INFO, LINK, START, ITEM, LOC, LOCP)
This procedure finds the location LOC of the first node N which contains
ITEM and the location LOCP of the node preceding node N.
If ITEM does not appear in the list, then sets LOC=NULL
If ITEM appear in the first node, then sets LOCP=NULL
1. [List Empty?] If START = NULL then:
Set LOC = NULL and LOCP = NULL and return.
FINDB(INFO, LINK, START, ITEM, LOC, LOCP)
This procedure finds the location LOC of the first node N which contains
ITEM and the location LOCP of the node preceding node N.
If ITEM does not appear in the list, then sets LOC=NULL
If ITEM appear in the first node, then sets LOCP=NULL
1. [List Empty?] If START = NULL then:
Set LOC = NULL and LOCP = NULL and return.
2. [ITEM in the first node?] If INFO[START] = ITEM, then:
Set LOC = START and LOCP = NULL and return.
FINDB(INFO, LINK, START, ITEM, LOC, LOCP)
This procedure finds the location LOC of the first node N which contains
ITEM and the location LOCP of the node preceding node N.
If ITEM does not appear in the list, then sets LOC=NULL
If ITEM appear in the first node, then sets LOCP=NULL
1. [List Empty?] If START = NULL then:
Set LOC = NULL and LOCP = NULL and return.
2. [ITEM in the first node?] If INFO[START] = ITEM, then:
Set LOC = START and LOCP = NULL and return.
3. Set SAVE=START and PTR = LINK[START] [initialize pointer]
FINDB(INFO, LINK, START, ITEM, LOC, LOCP)
This procedure finds the location LOC of the first node N which contains
ITEM and the location LOCP of the node preceding node N.
If ITEM does not appear in the list, then sets LOC=NULL
If ITEM appear in the first node, then sets LOCP=NULL
1. [List Empty?] If START = NULL then:
Set LOC = NULL and LOCP = NULL and return.
2. [ITEM in the first node?] If INFO[START] = ITEM, then:
Set LOC = START and LOCP = NULL and return.
3. Set SAVE=START and PTR = LINK[START] [initialize pointer]
4. Repeat step 5 and 6 while PTR ≠ NULL.
5. If INFO[SAVE] = ITEM then:
Set LOC= PTR and LOCP = SAVE and Return.
6. Set SAVE = PTR and PTR= LINK[PTR] [update pointer]
7. Set LOC= NULL
8. Exit.
• Circular linked lists
– The last node points to the first node of the list
– How do we know when we have finished traversing the list?
(Tip: check if the pointer of the current node is equal to the
head.)
circular linked list:
In a circular linked list there are two methods to know if a node is the
first node or not.
Either a external pointer, list, points the first node or
A header node is placed as the first node of the circular list.
The header node can be separated from the others by either heaving
a sentinel value as the info part or
having a dedicated flag variable to specify if the node is a header
node or not.
In computer programming, a sentinel value (also referred to as a flag value,
trip value, rogue value, signal value, or dummy data) is a special value
whose presence guarantees termination of an algorithm that processes
structured (especially sequential) data, typically a loop or recursive algorithm.
•The header node in a circular list can be specified by a sentinel value
or a dedicated flag:
•Header Node with Sentinel: Assume that info part contains positive
integers. Therefore the info part of a header node can be -1.
Header Node with Flag: In this case a extra variable called flag
can be used to represent the header node.
For example flag in the header node can be 1, where the flag is 0
for the other nodes.
A good example of an application where circular linked list
should be used is a timesharing problem solved by the
operating system.
In a timesharing environment, the operating system must
maintain a list of present users and must alternately allow
each user to use a small slice of CPU time, one user at a time.
The operating system will pick a user, let him/her use a small
amount of CPU time and then move on to the next user, etc.
For this application, there should be no NIL pointers unless
there is absolutely no one requesting CPU time.
Each node is accessible from any node.
Address of the first node is not needed.
Certain operations, such as concatenation and splitting of string, is
more efficient with circular linked list.
Disadvantage:
Danger of an infinite loop !
In linear linked lists if a list is traversed (all the elements
visited) an external pointer to the list must be preserved in
order to be able to reference the list again.
Circular linked lists can be used to help the traverse the
same list again and again if needed. A circular list is very
similar to the linear list where in the circular list the
pointer of the last node points not NULL but the first node.
Doubly linked lists
A linked list in which each node has three parts :one information and 2
pointers:
An information field which contains the data of node.
a forward pointer (a pointer to the next node in the list) and
a backward pointer (a pointer to the node preceding the current node in
the list) is called a doubly linked list.
A B C
Head
Each node points to not only successor but the predecessor
There are two NULL: at the first and last nodes in the list
–Advantage: given a node, it is easy to visit its predecessor.
Convenient to traverse lists backwards.
The primary disadvantage of doubly linked lists are that
(1) Each node requires an extra pointer, requiring more space, and
(2) The insertion or deletion of a node takes a bit longer (more pointer
operations).
A doubly linked list of lines in a document that may be kept by
a text editor. The following denotes how each node should
appear:
•To move backward and forward through the document (as it
appears on the screen ) and insert or delete lines, a doubly
linked list is ideal.
• With the cursor on the current line (stored in a pointer
"current"),
•it is easy to move up one line (current = current->prev) or
• down one line (current = current->next).
•With a singly linked list this is possible but probably too slow.
EXERCISE
1. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to traverse LIST.
EXERCISE
1. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to traverse LIST.
1. Set PTR:= LINK[START]
2. Repeat Step 3 and 4 while PTR != START
3. Write: INFO[PTR]
4. Set PTR:= LINK[PTR]
5. Exit
EXERCISE
2. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to find the location LOC
of the node where ITEM first appear in LIST.
EXERCISE
2. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to find the location LOC
of the node where ITEM first appear in LIST.
1. Set PTR:= LINK[START]
2. Repeat step 3 while INFO[PTR] != ITEM and PTR != START:
Set PTR:= LINK[PTR]
3. If INFO[PTR] := ITEM then:
Set LOC:= PTR
Else
Set LOC:= NULL
4. Exit
EXERCISE
3. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to find the location LOC
of the node where ITEM first appear in LIST.
EXERCISE
3. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to find the location LOC
of the node where ITEM first appear in LIST.
1. Set START:=1, ITEM:=200
2. If INFO[START] := ITEM then,
LOC:=START and go to step 5
Else Set PTR:= LINK[START] and go to step 3
3. Repeat step 4 while INFO[PTR] != ITEM and PTR != START:
Set PTR:= LINK[PTR]
4. If INFO[PTR] := ITEM then:
Set LOC:= PTR go to step 5
Else Set LOC:= NULL
5. Exit
EXERCISE
4. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to find LOC of node N that
contains ITEM and also location of node preceding N.
EXERCISE
4. Let LIST be a circular header list in memory. Write an algorithm and
draw flowchart to find LOC of node N that contains ITEM and also
location of node preceding N.
FIND(INFO,LINK,START,ITEM,LOC,LOCP)
1. Set START:=1, ITEM:=200
2. If INFO[START] := ITEM then,
LOC:=START and LOCP:= NULL go to step 6
Else Set PTR:= LINK[START] and go to step 3
3. Set SAVE:= START and PTR:=LINK[START]
4. Repeat step 5 while INFO[PTR] != ITEM and PTR != START:
Set SAVE:= PTR and PTR:= LINK[PTR]
5. If INFO[PTR] := ITEM then:
Set LOC:= PTR and LOCP:=SAVE
Else Set LOC:= NULL and LOCP:=SAVE
EXERCISE
5. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to delete the node N
which contains ITEM .
EXERCISE
5. Let LIST be a circular header list in memory. Write an
algorithm and draw flowchart to delete the node N
which contains ITEM .
1. Use procedure 3 to find LOC and LOCP
FIND(INFO,LINK,START,ITEM,LOC,LOCP)
2. If LOC=NULL, then Write: ITEM not found, and Exit
3. If LOCP:= NULL, then [delete first Node]
LINK[AVAIL]:=AVAIL and AVAIL:= START, and Exit
3. Set LINK[LOCP]:=LINK[LOC] [delete Node]
4. Set LINK[LOC]:=AVAIL and AVAIL:=LOC [update AVAIL LIST]
5. Exit
Wish
You
Good Luck
58