Грокаем а Иллюстрированное пособие для программистов и любопытствующих


Что лучше подойдет для вставки элементов в середину: массивы или списки? Со списком задача решается изменением указателя в предыдущем элементе



Download 3,16 Mb.
bet17/79
Sana19.02.2022
Hajmi3,16 Mb.
#457977
1   ...   13   14   15   16   17   18   19   20   ...   79
Bog'liq
Грокаем алгоритмы ( PDFDrive )

Что лучше подойдет для вставки элементов в середину: массивы или списки? Со списком задача решается изменением указателя в предыдущем элементе.



редположим, вы решили, что список задач должен больше напоминать календарь. Прежде данные добавлялись только в конец списка, а теперь они должны добавляться в порядке их выполнения.




t-r-srrf'l 1 X

■ ■■ 1 Q ОБЕЛ




О ОБЕЛ

Q ТРЕНИРОВКА




Г-\ ТРЕНИРОВКА , * •

CJ ЧАЕПИТИЕ




КУПИТЬ ЧАЙ

КУПИТЬ ЧАЙ




f-j ЧАЕПИТИЕ




} 4 а


Неупорядоченный


Упорядоченный

А при работе с массивом придется сдвигать вниз все остальные элементы.


П
ЭТУ ЗАДАЧУ НЕОБХОДИМО ВСТАвИТЬ СЮДА

ОБЕД

ТРЕНИ­
РОВКА

ЧАЕ­
ПИТИЕ







ш









ОЭТОААУ ЭТУ ЗАДАЧУ ПРИДЕТСЯ СДВИНУТЬ
sjT ВНИЗ
А если свободного места не осталось, все данные придется скопировать в новую область памяти! В общем, списки лучше подходят для вставки элементов в середину.
Удаление
Что, если вы захотите удалить элемент? И снова список лучше подходит для этой операции, потому что в нем достаточно изменить указатель в пре­дыдущем элементе. В массиве при удалении элемента все последующие элементы нужно будет сдвинуть вверх.
В отличие от вставки удаление возможно всегда. Попытка вставки может быть неудачной, если в памяти не осталось свободного места. С удалением подобных проблем не бывает.
Ниже приведены примеры времени выполнения основных операций с мас­сивами и связанными списками.
З




МАССИВЫ

списки

ЧТЕНИЕ

ОШ

О tn)

ЬСТАВКА

0(Ь>

О а)

УДАЛЕНИЕ

ООО

О СО




аметим, что вставка и удаление выполняются за время 0(1) только в том случае, если вы можете мгновенно получить доступ к удаляемому элементу. На практике обычно сохраняются ссылки на первый и последний элементы связанного списка, поэтому время удаления этих элементов составит всего 0
(1).
Какая структура данных используется чаще: массивы или списки? Очевидно, это зависит от конкретного сценария использования. Массивы чрезвычайно популярны из-за того, что они поддерживают произвольный доступ. Всего существуют два вида доступа: произвольный
и последовательный.
При по­следовательном доступе элементы читаются по одному, начиная с первого. Связанные списки поддерживают только последовательный доступ. Если вы захотите прочитать 10-й элемент связанного списка, вам придется прочитать первые 9 элементов и перейти по ссылкам к 10-му элементу. Я часто говорю, что массивы обладают более высокой скоростью чтения; это объясняется тем, что они поддерживают произвольный доступ. Многие реальные ситуа­ции требуют произвольного доступа, поэтому массивы часто применяются на практике. Также массивы и списки используются для реализации других структур данных (о которых будет рассказано в книге далее).
Упражнения

    1. Допустим, вы пишете приложение для приема заказов от посетителей ресторана. Приложение должно хранить список заказов. Официанты добавляют заказы в список, а повара читают заказы из списка и вы­полняют их. Заказы образуют очередь: официанты добавляют заказы в конец очереди, а повар берет первый заказ из очереди и начинает готовить.




Какую структуру данных вы бы использовали для реализации этой очереди: массив или связанный список? (Подсказка: связанные списки хорошо подходят для вставки/удаления, а массивы для произволь­ного доступа к элементам. Что из этого понадобится в данном случае?)

    1. Проведем мысленный эксперимент. Допустим, Facebook хранит список имен пользователей. Когда кто-то пытается зайти на сайт Facebook, система пытается найти имя пользователя. Если имя входит в список имен зарегистрированных пользователей, то вход разреша­ется. Пользователи приходят на Facebook достаточно часто, поэтому поиск по списку имен пользователей будет выполняться часто. Будем считать, что Facebook использует бинарный поиск для поиска в спи­ске. Бинарному поиску необходим произвольный доступ алгоритм должен мгновенно обратиться к среднему элементу текущей части списка. Зная это обстоятельство, как бы вы реализовали список поль­зователей: в виде массива или в виде связанного списка?

    2. Пользователи также довольно часто создают новые учетные записи на Facebook. Предположим, вы решили использовать массив для хране­ния списка пользователей. Какими недостатками обладает массив для выполнения вставки? Допустим, вы используете бинарный поиск для нахождения учетных данных. Что произойдет при добавлении новых пользователей в массив?

    3. В

      Download 3,16 Mb.

      Do'stlaringiz bilan baham:
1   ...   13   14   15   16   17   18   19   20   ...   79




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