当前位置:
首页 > Python基础教程 >
-
Python实现堆栈和队列详解(2)
再写一个程序文件,stacktest.py 使用栈,内容如下:
代码如下:
1
2
3
4
5
6
7
|
#!/usr/bin/python from stack import Stack s = Stack( 20 ) for i in range ( 3 ): s.push(i) s.pop() print s.isempty() |
python 实现队列
队列是一种先进先出的数据类型,它的跟踪原理类似于在超市收银处排队,队列里的的第一个人首先接受服务,新的元素通过入队的方式添加到队列的末尾,而出队就是将队列的头元素删除。
我们可以设置一个类,用列表来存放栈中元素的信息,利用列表的append()和pop()方法可以实现队列的入队enqueue和出队dequeue的操作,上面栈一个元素每次出去是列表的最后一个,直接用list.pop()出栈,而出队列每次是第一个,所以要用list.pop(0)出队列
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
class Queue(): def __init__( self ,size): self .size = size; self .front = - 1 ; self .rear = - 1 ; self .queue = []; def enqueue( self ,ele): #入队操作 if self .isfull(): raise exception( "queue is full" ); else : self .queue.append(ele) self .rear = self .rear + 1 def dequeue( self ): #出队操作 if self .isempty(): raise exception( "queue is empty" ) else : self .front = self .front + 1 return self .queue[ self .front] def isfull( self ): return self .rear - self .front + 1 = = self .size def isempty( self ): return self .front = = self .rear q = Queue( 10 ); for i in range ( 3 ): q.enqueue(i) print q.dequeue() print q.isempty() |
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式