编号001:deque用法暂时总结
#deque的用法总结 In [1]: """
所在地址:from collections import deque
现在知道的情况总结:
1.deque的用法与list的操作很像
1.队列增加数据3种方式:append(left), insert, extend(left)。
2.删除数据2种方式:remove, pop(left)。需要注意返回值,remove删除的是第一个匹配项返回删除后的列表,pop删除后返回删除的元素
3.统计元素个数1种方式:count(argv)。
4.查找元素位置1种方式:index(argv)。找不到的时候结果怎样?
5.排序1种方式:reverse。
2.特性:用来保留历史数据,用来保留最新的5个数据,其他的更久的数据不保存。
1.参数设定:deque(maxlen=5), maxlen必须要指定。
2.没有指定参数时deque的处理方式与list类似,可以无穷大 """
#方法操作如下:
from collections import deque In [6]: #增加元素方式:
#1. append
def append_test001():
append_test = deque()
append_test.append("appent_test_001")
print("增加第一个元素")
print(append_test)
append_test.append("appent_test_002")
print("增加第二个元素")
print(append_test)
append_test.appendleft("appent_test_left_001")
print("在开头增加元素")
print(append_test)
print("##append_test001:")
print(append_test) append_test001() 增加第一个元素
deque(['appent_test_001'])
增加第二个元素
deque(['appent_test_001', 'appent_test_002'])
在开头增加元素
deque(['appent_test_left_001', 'appent_test_001', 'appent_test_002'])
##append_test001:
deque(['appent_test_left_001', 'appent_test_001', 'appent_test_002'])
In [10]: #2. insert
def insert_test001():
insert_test = deque()
insert_test.insert(0,"insert001") #注意insert需要传递两个参数,其中第一个参数是需要插入的位置
print(insert_test) insert_test001() deque(['insert001'])
In [14]: #3. extend
def extend_test001():
extend_test = deque()
extend_test.extend([1,2,3])
print("在右侧追加:")
print(extend_test)
extend_test.extendleft([4,5,6,6])
print("在左侧追加:")
print(extend_test) extend_test001() 在右侧追加:
deque([1, 2, 3])
在左侧追加:
deque([6, 6, 5, 4, 1, 2, 3])
In [16]: #4. remove
def remove_test001():
remove_test = deque()
remove_test.extend([1,23,4,45,1,2,2,4])
print("最原始的remove_test:")
print(remove_test)
remove_test.remove(1)
print("删除其中一个元素1后:")
print(remove_test)
print("准备删除一个不存在的元素9:")
remove_test.remove(9)
print(remove_test)
remove_test001() 最原始的remove_test:
deque([1, 23, 4, 45, 1, 2, 2, 4])
删除其中一个元素1后:
deque([23, 4, 45, 1, 2, 2, 4])
准备删除一个不存在的元素9: ---------------------------------------------------------------------------
ValueError Traceback (most recent call last)
<ipython-input-16-4e5363eb2dd4> in <module>()
11 remove_test.remove(9)
12 print(remove_test)
---> 13 remove_test001() <ipython-input-16-4e5363eb2dd4> in remove_test001()
9 print(remove_test)
10 print("准备删除一个不存在的元素9:")
---> 11 remove_test.remove(9)
12 print(remove_test)
13 remove_test001() ValueError: deque.remove(x): x not in deque In [22]: #5. pop
def pop_test001():
pop_test = deque()
pop_test.extend([1,2,4,5,65,6,7,7])
print("删除前:")
print(pop_test)
a = pop_test.pop()
print("查看返回值:")
print(a)
print("执行一次pop后:")
print(pop_test)
b = pop_test.popleft()
print("执行一次popleft")
print("查看返回值")
print(b)
print("删除后的结果:")
print(pop_test)
#下面的代码是警告自己,pop没有参数指定
print("删除一个不存在的元素10:")
pop_test.pop(10)
print(pop_test) pop_test001() 删除前:
deque([1, 2, 4, 5, 65, 6, 7, 7])
查看返回值:
7
执行一次pop后:
deque([1, 2, 4, 5, 65, 6, 7])
执行一次popleft
查看返回值
1
删除后的结果:
deque([2, 4, 5, 65, 6, 7])
In [26]: #6. count, index
def count_test001():
count_test = deque()
count_test.extend([1,2,3,4,5,6,62,2,1,2])
print("初始值:")
print(count_test)
print("统计1得数目")
print(count_test.count(1))
print("统计一个不存在元素:10")
print(count_test.count(10))
print("获取62所在位置")
print(count_test.index(62))
print("获取一个不存在得元素得位置:10")
print(count_test.index(10)) count_test001() 初始值:
deque([1, 2, 3, 4, 5, 6, 62, 2, 1, 2])
统计1得数目
2
统计一个不存在元素:10
0
获取62所在位置
6
获取一个不存在得元素得位置:10 ---------------------------------------------------------------------------
ValueError Traceback (most recent call last)
<ipython-input-26-d09d49a25f91> in <module>()
14 print(count_test.index(10))
15
---> 16 count_test001() <ipython-input-26-d09d49a25f91> in count_test001()
12 print(count_test.index(62))
13 print("获取一个不存在得元素得位置:10")
---> 14 print(count_test.index(10))
15
16 count_test001() ValueError: 10 is not in deque In [30]: #7. reverse
def reverse_test001():
reverse_test = deque()
reverse_test.extend([1,2,3,5,67,1,23,5,23,2,3,4])
print("最开始的数据:")
print(reverse_test)
reverse_list = reverse_test.reverse()
print("reverse后的返回值:")
print(reverse_list)
print("原deque:")
print(reverse_test) reverse_test001() 最开始的数据:
deque([1, 2, 3, 5, 67, 1, 23, 5, 23, 2, 3, 4])
reverse后的返回值:
None
原deque:
deque([4, 3, 2, 23, 5, 23, 1, 67, 5, 3, 2, 1])
In [32]: #8. 保留最新5个数据
def leave_last_data():
leave_data = deque(maxlen=5)
leave_data.extend([1,2,3,4,5,6,7,7])
print(leave_data) leave_last_data() deque([4, 5, 6, 7, 7], maxlen=5)
In [ ]:
编号001:deque用法暂时总结的更多相关文章
- STL之deque用法详解
C++ Deque(双向队列): Deque是一种优化了的.对序列两端元素进行添加和删除操作的基本序列容器.它允许较为快速地随机访问,但它不像vector 把所有的对象保存在一块连续的内存块,而是采用 ...
- deque用法 和与vector的区别
deque是双向开口的连续性存储空间.虽说是连续性存储空间,但这种连续性只是表面上的,实际上它的内存是动态分配的,它在堆上分配了一块一块的动态储存区,每一块动态存储去本身是连续的,deque自身的机制 ...
- STL:deque用法详解
deque函数: deque容器为一个给定类型的元素进行线性处理,像向量一样,它能够快速地随机访问任一个元素,并且能够高效地插入和删除容器的尾部元素.但它又与vector不同,deque支持高效插入和 ...
- STL deque用法
Deque 容器 deque容器是C++标准模版库(STL,Standard Template Library)中的部分内容.deque容器类与vector类似,支持随机访问和快速插入删除,它在容器中 ...
- STL之三:deque用法详解
转载于:http://blog.csdn.net/longshengguoji/article/details/8519812 deque函数: deque容器为一个给定类型的元素进行线性处理,像向量 ...
- STL之deque用法
deque:双端队列 底层是一个双向链表. 常用的有队列的尾部入队.首部出队. 普通队列:queuequeue 模板类的定义在<queue>头文件中.与stack 模板类很相似,queue ...
- deque 用法
引用博客:https://blog.csdn.net/zyq522376829/article/details/46801973 下面是那位大佬写的的笔记整理~~~~ deque - 双向队列 1.构 ...
- Python:每日一题001
题目:有四个数字:1.2.3.4,能组成多少个互不相同且无重复数字的三位数?各是多少? **程序分析:可填在百位.十位.个位的数字都是1.2.3.4.组成所有的排列后再去 掉不满足条件的排列. 个人解 ...
- C++之deque
deque(包含头文件#include<deque>)由若干段连续空间串接而成,一旦有必要在deque的头部或尾端增加新的空间,便配置一段定量连续的空间,串接在deque的头部或尾端.de ...
随机推荐
- cmake 简单操作
实例一: main.c #include <stdio.h> int main( int argc, char *argv[] ) { printf("hello cmake!\ ...
- Python实用黑科技——找出最大/最小的n个元素
需求: 快速的获取一个列表中最大/最小的n个元素. 方法: 最简便的方法是使用heapq模组的两个方法nlargest()和nsmallest(),例如: In [1]: import heapqIn ...
- JavaWeb_Servlet生命周期
菜鸟教程 传送门 Servlet生命周期 package com.Gary.servlet; import java.io.IOException; import javax.servlet.Serv ...
- 个推CTO深度解析数据智能之多维度分析系统的选型方法
引言 前文回顾:[<数据智能时代来临:本质及技术体系要求>][2]作为本系列的第一篇文章,概括性地阐述了对于数据智能的理解以及推出了对应的核心技术体系要求: 数据智能就是以数据作为生产资料 ...
- linux系统基础优化及高级操作命令
Linux基础系统优化 引言没有,只有一张图. Linux的网络功能相当强悍,一时之间我们无法了解所有的网络命令,在配置服务器基础环境时,先了解下网络参数设定命令. ifconfig 查询.设置网卡和 ...
- cgo
package main import ( "unsafe" "fmt") /*#cgo CFLAGS: -I./#cgo LDFLAGS: -L./#incl ...
- leetcode-easy-math-13 Roman to Integer
mycode 97.21% class Solution(object): def romanToInt(self, s): """ :type s: str :rty ...
- 自定义Chrome的console(样式、打印图片、开关)
1.常用console类型 console.log() 常规打印 console.warn() 打印警告信息 console.error() 打印错误信息 console.time() 和 conso ...
- leetcode 454 四数相加
采用一个哈希表存储两个数的和,再遍历另外两个数组的和,time O(n2) space O(n2) class Solution { public: int fourSumCount(vector&l ...
- [flask]jinjia2处理表单-实现搜索界面
思路: 通过flask-wtf创建forms表单类 在app.py中创建search_name()视图函数,实例化form表单类,将通过render_template将form传给html模板 创建h ...