Introduction to Algorithms, Third Edition


error “underflow” 3 else



Download 4,84 Mb.
Pdf ko'rish
bet151/618
Sana07.04.2022
Hajmi4,84 Mb.
#534272
1   ...   147   148   149   150   151   152   153   154   ...   618
Bog'liq
Introduction-to-algorithms-3rd-edition

error
“underflow”
3
else
S:
top
D
S:
top
1
4
return
S ŒS:
top
C
1
Figure 10.1 shows the effects of the modifying operations P
USH
and P
OP
. Each of
the three stack operations takes
O.1/
time.


234
Chapter 10
Elementary Data Structures
1
2
3
4
5
6
7
8
9
10 11 12
Q
(a)
15 6
9
8
4
1
2
3
4
5
6
7
8
9
10 11 12
Q
(b)
15 6
9
8
4
3
5
17
1
2
3
4
5
6
7
8
9
10 11 12
Q
(c)
15 6
9
8
4
3
5
17
Q:
head
D
7
Q:
head
D
7
Q:
tail
D
12
Q:
tail
D
3
Q:
tail
D
3
Q:
head
D
8
Figure 10.2
A queue implemented using an array
QŒ1 : : 12
. Queue elements appear only in the
lightly shaded positions.
(a)
The queue has 5 elements, in locations
QŒ7 : : 11
.
(b)
The configuration
of the queue after the calls E
NQUEUE
.Q; 17/
, E
NQUEUE
.Q; 3/
, and E
NQUEUE
.Q; 5/
.
(c)
The
configuration of the queue after the call D
EQUEUE
.Q/
returns the key value 15 formerly at the
head of the queue. The new head has key 6.
Queues
We call the I
NSERT
operation on a queue E
NQUEUE
, and we call the D
ELETE
operation D
EQUEUE
; like the stack operation P
OP
, D
EQUEUE
takes no element ar-
gument. The FIFO property of a queue causes it to operate like a line of customers
waiting to pay a cashier. The queue has a
head
and a
tail
. When an element is en-
queued, it takes its place at the tail of the queue, just as a newly arriving customer
takes a place at the end of the line. The element dequeued is always the one at
the head of the queue, like the customer at the head of the line who has waited the
longest.
Figure 10.2 shows one way to implement a queue of at most
n
1
elements
using an array
QŒ1 : : n
. The queue has an attribute
Q:
head
that indexes, or points
to, its head. The attribute
Q:
tail
indexes the next location at which a newly arriv-
ing element will be inserted into the queue. The elements in the queue reside in
locations
Q:
head
; Q:
head
C
1; : : : ; Q:
tail
1
, where we “wrap around” in the
sense that location
1
immediately follows location
n
in a circular order. When
Q:
head
D
Q:
tail
, the queue is empty. Initially, we have
Q:
head
D
Q:
tail
D
1
.
If we attempt to dequeue an element from an empty queue, the queue underflows.


10.1
Stacks and queues
235
When
Q:
head
D
Q:
tail
C
1
, the queue is full, and if we attempt to enqueue an
element, then the queue overflows.
In our procedures E
NQUEUE
and D
EQUEUE
, we have omitted the error checking
for underflow and overflow. (Exercise 10.1-4 asks you to supply code that checks
for these two error conditions.) The pseudocode assumes that
n
D
Q:
length
.
E
NQUEUE
.Q; x/
1
QŒQ:
tail
D
x
2

Download 4,84 Mb.

Do'stlaringiz bilan baham:
1   ...   147   148   149   150   151   152   153   154   ...   618




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish