48 lines
2.5 KiB
Org Mode
48 lines
2.5 KiB
Org Mode
:PROPERTIES:
|
|
:ID: cb3c63b9-6452-4016-9b2f-a25784941d5d
|
|
:mtime: 20211230202924
|
|
:ctime: 20211230192608
|
|
:END:
|
|
#+title: List vs deque
|
|
#+filetags: :Optimisation:Python:
|
|
|
|
* /Deque/
|
|
Classe du module /collections/ écrite afin de réaliser une queue plus efficace que la /list/.
|
|
|
|
Caractéristiques principales :
|
|
* Ecrite en C (.cf [[https://github.com/python/cpython/blob/main/Modules/_collectionsmodule.c][Github)]],
|
|
* Liste doublement chainée et avec une double queue (contrairement à /list/ ayant une simple queue, à droite),
|
|
* Peut contenir des objets de types différents,
|
|
* Les méthodes /pop/, /append/, /appendleft/ et /popleft/ sont /thread-safe/,
|
|
* Object mutable,
|
|
* Supporte les /membership operations/ (opérateur /in/),
|
|
* Supporte l'indexation (par exemple, d[2]),
|
|
* Supporte les fonctions fonctionnant avec les /sequences/ et /iterables/ (par exemple, /len()/, /sorted()/),
|
|
* Supporte l'itération et l'itération inversée,
|
|
* Supporte le /picking/ (/pickle/),
|
|
* Ne supporte pas le /slicing/ (par exemple, d[0:2]) et le rangement (/sorting/) /in-place/ (par exemple: //[3, 1, 2].sort()//),
|
|
|
|
Illustration de la liste doublement chainées (/deque/) :
|
|
#+DOWNLOADED: https://res.cloudinary.com/practicaldev/image/fetch/s--qPBdx2qm--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/i/8oq2m41oivizbdltb6p9.png @ 2021-12-30 19:50:53
|
|
#+ATTR_ORG: :width 500
|
|
[[file:Deque/8oq2m41oivizbdltb6p9_2021-12-30_19-50-53.png]]
|
|
|
|
Figure illustrant l'intérêt d'une chaine doublement chainée afin de réaliser une /queue/:
|
|
#+DOWNLOADED: https://res.cloudinary.com/practicaldev/image/fetch/s--lB01CsB4--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/i/ygqm1fk0kmm6waj0wvgi.png @ 2021-12-30 19:54:42
|
|
#+ATTR_ORG: :width 500
|
|
[[file:Deque/ygqm1fk0kmm6waj0wvgi_2021-12-30_19-54-42.png]]
|
|
|
|
* /Deque/ vs /list/
|
|
Based on Big-O notation:
|
|
| | Deque | List |
|
|
| Access by an index | O(n) | O(1) |
|
|
| Append/pop at the beginning | O(1) | O(n) |
|
|
| Append/pop at the end | O(1) | O(1) + reallocation time |
|
|
| Insert in the middle | O(n) | O(n) |
|
|
|
|
La /deque/ est plus performante que la /list/, hormis pour l'accès par index.
|
|
|
|
* Références
|
|
* [[https://realpython.com/python-deque/][RealPython]]
|
|
* [[https://dev.to/v_it_aly/python-deque-vs-listwh-25i9][Python deque vs list (Vitaly Shchurov)]]
|