广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python中栈的详细介绍
  • 806
分享到

Python中栈的详细介绍

2024-04-02 19:04:59 806人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录1、问题描述2、解决方案3、结语本文转自公众号:"算法与编程之美" 1、问题描述 python中数据类型有列表,元组,字典,队列,栈,树等等。像列表,元组这样的都是Python内

本文转自公众号:"算法与编程之美"

1、问题描述

python中数据类型有列表,元组,字典,队列,栈,树等等。像列表,元组这样的都是Python内置数据结构;栈,队列这些都是需要我们自己去定义的。

栈是一种只允许在一端插入和取出的数据结构,这一端通常被叫做栈顶,另一端叫栈底,没有数据的叫空栈。这种数据类型由于是我们自己进行定义,所以有很多功能都需要自己写出相应函数来实现。所以我们看看这里的功能。

2、解决方案

栈的基本操作大概有:生成栈,入栈,出栈,返回栈顶元素,判断是否为空栈,返回栈内元素个数。

首先我们先要创建一个栈:


class stack(object):

    def  __init__(self):

         self.__list =  []

这里创建出来就是一个空栈,想要检测的话我们也可以通过一个函数来检测是否为空栈:


def is_empty(self):

    return  self.__list == []

    #  return not self.__list

这是两种return的检测方式,任选其一都能够完成。
接下来创建了栈,也知道了检测栈是否为空。如定义所说,因为栈是我们自己定义的一种数据结构,且满足一个后进先出的规则,那么元素的保存和取出也自然不同。我们叫做入栈和出栈。首先是入栈,我么仅需要定义一个push函数:


def push(self,item):

     self.__list.append(item)

然后定义一个函数pop来进行出栈:


def pop(self):

     self.__list.pop()

peek函数进行返回栈顶元素操作:


def peek(self):

    if  self.__list:

         return self.__list[-1]

    else:

         return None

size函数进行返回栈的元素个数的操作:


def size(self):

    return  len(self.__list)

3、结语

以上便是栈这种数据结构的大概用法,通过定义各种函数,然后在使用时直接调用,这样也显得非常的方便。

定义栈的函数时,特别要注意的是里面关键词的使用,例如__list,__init__,中的下划线的使用,这些都是系统内定的,不能轻易改变,不然很容易让系统报错。

到此这篇关于Python中栈的详细介绍的文章就介绍到这了,更多相关Python中的栈内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Python中栈的详细介绍

本文链接: https://www.lsjlt.com/news/157631.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python中栈的详细介绍
    目录1、问题描述2、解决方案3、结语本文转自公众号:"算法与编程之美" 1、问题描述 Python中数据类型有列表,元组,字典,队列,栈,树等等。像列表,元组这样的都是python内...
    99+
    2022-11-12
  • Android Fragment的回退栈示例详细介绍
    Android  Fragment的回退栈 点开之后按一次回退键只返回一次 MainActivity 类 public class MainActivity ex...
    99+
    2022-06-06
    示例 fragment Android
  • Python中的列表详细介绍
    本篇内容主要讲解“Python中的列表详细介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python中的列表详细介绍”吧!Python中的for循环Python中的for循环语句按顺序遍历任...
    99+
    2023-06-16
  • Python全栈MySQL数据库基本操作的详细介绍
    下文给大家带来有关Python全栈MySQL数据库基本操作的详细内容,相信大家一定看过类似的文章。我们给大家带来的有何不同呢?一起来看看正文部分吧,相信看完Python全栈MySQL数据库基本操作你一定会有...
    99+
    2022-10-18
  • 详细介绍Python中的set集合
    目录Python中的set集合一、集合是什么?二、set集合怎么用?1、创建set集合2、删除set集合3、访问set集合元素4、删除集合中的元素5、向集合中添加元素三、set集合的...
    99+
    2022-11-12
  • python中re模块的详细介绍
    本篇内容介绍了“python中re模块的详细介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!正则表达式的元字符有. ^ $ * { [ ...
    99+
    2023-06-04
  • Python中数据类型的详细介绍
    这篇文章主要讲解了“Python中数据类型的详细介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python中数据类型的详细介绍”吧!目录1、字符串2、布尔类型3、整数4、浮点数5、数字6...
    99+
    2023-06-02
  • Python中类型检查的详细介绍
    前言 大家都知道Python 是一门强类型、动态类型检查的语言。所谓动态类型,是指在定义变量时,我们无需指定变量的类型,Python 解释器会在运行时自动检查。 与静态类型语言(如 C 语言)相比,这不仅仅...
    99+
    2022-06-04
    详细介绍 类型 Python
  • Python 模块EasyGui详细介绍
    Python 模块EasyGui详细介绍 前言: 在Windows想用Python开发一些简单的界面,所以找到了很容易上手的EasyGui库。下面就分享一下简单的使用吧。 参考的链接:官网Tutorial ...
    99+
    2022-06-04
    详细介绍 模块 Python
  • Python Socket编程详细介绍
    在使用Python做socket编程时,由于需要使用阻塞(默认)的方式来读取数据流,此时对于数据的结束每次都需要自己处理,太麻烦。并且网上也没找到太好的封装,所以就自己写了个简单的封装。 封装思路 1....
    99+
    2022-06-04
    详细介绍 Python Socket
  • Python 字典(Dictionary)详细介绍
    目录1.访问字典里的值2.修改字典3.删除字典元素3.1字典键的特性4.字典内置函数&方法字典是另一种可变容器模型,且可存储任意类型对象。 字典的每个键值 key=>v...
    99+
    2022-11-13
  • Python torch.onnx.export用法详细介绍
    目录函数原型参数介绍mode (torch.nn.Module, torch.jit.ScriptModule or torch.jit.ScriptFunction)args (t...
    99+
    2022-11-11
  • Python装饰器详细介绍
    目录装饰器一、介绍二、通过高阶函数+嵌套函数==>实现装饰器1、变量知识回顾2、高阶函数(装饰器前奏)3、嵌套函数(装饰器前戏)三、装饰器1、装饰器2、有参装饰器3、终极装饰器...
    99+
    2022-11-13
  • Flink的详细介绍
    这篇文章主要介绍“Flink的详细介绍”,在日常操作中,相信很多人在Flink的详细介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Flink的详细介绍”的疑惑有所帮助!接...
    99+
    2022-10-19
  • rabbitMQ的详细介绍
    1.概述 RabbitMQ是一个消息中间件:它接受并转发消息。你可以把它当做一个快递站点,当你要发送一个包裹时,你把你的包裹放到快递站,快递员最终会把你的快递送到收件人那里,按照这种逻辑RabbitMQ是一个快递站,一个快递员帮你传递快件。...
    99+
    2023-09-05
    rabbitmq npm linux java 分布式
  • Android中的WebView详细介绍
    Android中WebView的详细解释: 1. 概念: WebView(网络视图)能加载显示网页,可以将其视为一个浏览器。它使用了WebKit渲染引擎加载显示网页。 2. ...
    99+
    2022-06-06
    webview Android
  • jQuery中Ajax的详细介绍
    这篇文章主要介绍“jQuery中Ajax的详细介绍”,在日常操作中,相信很多人在jQuery中Ajax的详细介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”jQuery中A...
    99+
    2022-10-19
  • Java中CompletableFuture 的详细介绍
    目录1.概述1.0 创建 CompletableFuture 的对象的工厂方法1.1 non-async 和 async 区别1.1.1 non-async 示例:注册 action...
    99+
    2022-11-13
  • OAuth2 详细介绍!
    目录 一、文章介绍 二、OAth2 2.1 简介 2.2 OAuth2  授权总体流程 2.3 四种授权模式 1.授权码模式 2.简化模式 3.密码模式 4. 客户端模式 2.4 OAuth2 标准接口 2.5 GitHub 授权登录 1...
    99+
    2023-09-15
    github java
  • springMVC详细介绍
    目录springMVC简介SpringMVC框架的优点第一个SpringMVC程序第一步:创建maven-web项目第二步:在pom.xml中添加依赖和插件第三步注册中央调度器第四步...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作