網(wǎng)站首頁 編程語言 正文
1 概要
deque 是一個雙端隊列, 如果要經(jīng)常從兩端append 的數(shù)據(jù), 選擇這個數(shù)據(jù)結(jié)構(gòu)就比較好了, 如果要實現(xiàn)隨機(jī)訪問,不建議用這個,請用列表.
deque 優(yōu)勢就是可以從兩邊append ,appendleft 數(shù)據(jù). 這一點list 是沒有的.
#-*- coding: UTF-8 -*-
import time
from collections import deque
# 可以指定 隊列的長度
mydeque=deque(maxlen=10)
mydeque.maxlen
Out[43]: 10
# 默認(rèn)從右邊加入
mydeque.append(10)
mydeque.append(12)
mydeque
Out[7]: deque([10, 12])
# time.sleep(4)
# 也可以從左邊加入
mydeque.appendleft('a')
mydeque.appendleft('b')
mydeque.appendleft('c')
mydeque.appendleft('d')
mydeque.appendleft('e')
mydeque
Out[11]: deque(['e', 'd', 'c', 'b', 'a', 10, 12])
mylist= range(5,8)
# 也可以加入一個列表,默認(rèn)從右邊加入
# mydeque.extend(mylist)
mydeque.extendleft(mylist)
mydeque
Out[14]: deque([7, 6, 5, 'e', 'd', 'c', 'b', 'a', 10, 12])
# 出隊列,返回出隊列的元素
# 可以從左邊也可以從右邊 出隊列
mydeque.pop()
mydeque.popleft()
# 查看 隊列里面元素個數(shù)
print len(mydeque)
# 統(tǒng)計元素的個數(shù)
#統(tǒng)計a 有幾個
print mydeque.count('a')
# 在某個位置insert 一個元素
# insert(i, x)
# Insert x into the deque at position i.
d1
Out[31]: deque([10, 12, 13, 14])
d1.insert(2,'frank')
d1
Out[33]: deque([10, 12, 'frank', 13, 14])
#翻轉(zhuǎn)操作
# deque.reverse()
mydeque
Out[52]: deque([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
mydeque.reverse()
mydeque
Out[54]: deque([9, 8, 7, 6, 5, 4, 3, 2, 1, 0])
# remove 移除某個元素
mydeque
Out[23]: deque(['e', 'd', 'c', 'b', 'a', 10, 12])
mydeque.remove(10)
mydeque
Out[25]: deque(['e', 'd', 'c', 'b', 'a', 12])
# 清空隊列元素 clear
mydeque
Out[46]: deque([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
mydeque.clear
Out[47]: <function deque.clear>
mydeque.clear()
mydeque
Out[49]: deque([])
# copy 淺拷貝
# Create a shallow copy of the deque.
l1 = [6, 5, 8, 3, 9, 0, 2, 7, 4, 1]
d3 = deque(l1)
d3
Out[64]: deque([6, 5, 8, 3, 9, 0, 2, 7, 4, 1])
d4 = d3.copy()
d4
Out[66]: deque([6, 5, 8, 3, 9, 0, 2, 7, 4, 1])
2 重要方法說明
rotate 方法:
移動到最后一個,占用第一個位置,循環(huán)移動, value 是步長,rotate(value) 對隊列實行旋轉(zhuǎn)操作(每個元素依次向后移動value步,最后一個移動到第一個算一步)
from collections import deque
d = deque()
d.extend(['a', 'b', 'c', 'd', 'e'])
d.rotate(2) # 指定次數(shù),默認(rèn)1次
print(d) # deque(['d', 'e', 'a', 'b', 'c'])
maxlen 要說明一下, 如果指定了 maxlen
- 如果構(gòu)建deque 的時候,指定了maxlen, 則可以通過 d.maxlen 來獲得dueue的最大長度.
- 如果插入的數(shù)據(jù)大于 maxlen 則會自動刪除舊的元素.
- 刪除 什么元素,取決于, 從哪邊添加數(shù)據(jù).
來看一下例子:
d = deque(list(range(5)),maxlen=5)
d
Out[21]: deque([0, 1, 2, 3, 4])
d.maxlen
Out[26]: 5
# 從左邊添加元素, # 元素4 被擠出 隊列
d.appendleft('frank')
d
Out[23]: deque(['frank', 0, 1, 2, 3])
# 從右邊添加元素, 元素 'frank' 被擠出隊列.
d
Out[23]: deque(['frank', 0, 1, 2, 3])
d.append('xiaoming')
d
Out[25]: deque([0, 1, 2, 3, 'xiaoming'])
3 總結(jié)
deque 是為了高效實現(xiàn)插入和刪除操作的雙向列表
總結(jié) :
- deque ?的方法 雙端隊列 ,進(jìn)入隊列,默認(rèn)從右邊進(jìn)入,?
- 出隊列 ?默認(rèn)從右邊出隊列, ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
- 移除隊列元素?
- insert()
- appendleft()
- append()
- extend(...)
- extendleft(...)
隊列長度 ?len(deque)
- pop()
- popleft()
count(value) ? # 統(tǒng)計某個值出現(xiàn)的個數(shù)
remove(...)
reverse() ??
#輪詢向前走n,最后一個元素往前移動,第一個元素依次后移?
rotate(n=1)
清空隊列: dequeue.clear()
deque 官方文檔
原文鏈接:https://blog.csdn.net/u010339879/article/details/80767293
相關(guān)推薦
- 2022-10-29 python實現(xiàn)k均值聚類(kMeans)基于numpy
- 2022-05-18 Matlab實現(xiàn)多子圖同步調(diào)整視角_C 語言
- 2022-11-07 python學(xué)習(xí)pymongo模塊的使用方法_python
- 2022-08-22 詳解golang執(zhí)行Linux?shell命令完整場景下的使用方法_Golang
- 2022-07-18 Uniapp中調(diào)整web-view的高度、獲取當(dāng)前的web-view頁面URL
- 2022-10-28 Go操作Kafka和Etcd方法詳解_Golang
- 2022-11-04 ASP.NET?MVC獲取多級類別組合下的產(chǎn)品_實用技巧
- 2022-12-29 解決React報錯You?provided?a?`checked`?prop?to?a?form?f
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支