ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python基本数据结构类型--初识栈

2020-03-28 21:00:10  阅读:208  来源: 互联网

标签:return python items self pop item 初识 数据结构 def


python基本数据结构类型--初识栈

MOOC课程 《数据结构与算法》(北大地空)笔记
by dlnb526
2020.3

预备知识:线性结构(线性表)

前驱后继

线性结构的特点就在于其线性,也就是说整个结构里面的元素都只有一个前驱和一个后继(除了开头和结尾的元素),就像是一串糖葫芦或者列车一样。
当我们向线性结构中添加一个项目时,他会放在之前的项和后来的项之间。

什么是栈

  1. 栈是线性结构
  2. 栈是一个项的有序集合
  3. 栈遵循LIFO原则

    LIFO原则(Last in, First out.后进先出)。栈的添加项和移除项都会发生在同一端,另一端我们不妨称之为‘底’。这样每当添加一个项,原本就靠近‘底’的元素就会更加被压在底下,因此它在栈中存储的时间会更长。

栈的抽象数据类型

  • Stack(): 创建一个新的空栈,它不需要参数并返回一个空栈。
  • push(item): 将一个新项目添加到堆栈的顶部。
  • pop(): 从栈顶删除项目,不需要参数,返回所删除的item,进行操作后栈会被修改
  • peek(): 返回栈顶的项,不删除。
  • isEmpty(): 测试栈是否为空,返回一个布尔值
  • size(): 返回栈的项目数

接下来我们通过python来构建上面的栈的结构。

构建栈

# Bradley N. Miller, David L. Ranum
# Introduction to Data Structures and Algorithms in Python
# Copyright 2005
# 
#stack.py

class Stack:
    def __init__(self):
        self.items = []

    def isEmpty(self):
        return self.items == []

    def push(self, item):
        self.items.append(item)

    def pop(self):
        return self.items.pop()

    def peek(self):
        return self.items[len(self.items)-1]

    def size(self):
        return len(self.items)

通过上面的方法就完成了栈的构建。

复杂度分析

对栈进行操作,其实都是相当于直接对列表的尾端进行操作,因此我们可以知道其时间复杂度如下:

操作 复杂度
push(item) O(1)
pop() O(1)
peek() O(1)
isEmpty() O(1)
size() O(1)

之后

下次的内容将是栈的两个应用举例~

标签:return,python,items,self,pop,item,初识,数据结构,def
来源: https://www.cnblogs.com/dlnb526/p/12589336.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有