1. 7 """
  2. 8 用一个类来实现一个节点
  3. 9 """
  4. 10 class Node(object):
  5. 11 def __init__(self,data):
  6. 12 self.data = data
  7. 13 self.next = None
  8. 14 class linkstack(object):
  9. 15 def __init__(self):
  10. 16 self.top = None
  11. 17 def isEmpty(self):
  12. 18 return self.top == None
  13. 19 def clear(self):
  14. 20 self.top = None
  15. 21 def length(self):
  16. 22 i = 0
  17. 23 tempnode =self.top
  18. 24 while tempnode is not None:
  19. 25 tempnode = tempnode.next
  20. 26 i += 1
  21. 27 return i
  22. 28 def push(self,item):
  23. 29 node = Node(item)
  24. 30 node.next = self.top
  25. 31 self.top = node
  26. 32 def pop(self):
  27. 33 self.top = self.top.next
  28. 34 def gettop(self):
  29. 35 return self.top.data
  30. 36 def display(self):
  31. 37 if self.top == None:
  32. 38 print("None")
  33. 39 tempnode = self.top
  34. 40 while tempnode is not None:
  35. 41 print(tempnode.data,end = " ")
  36. 42 tempnode = tempnode.next
  37. 43 print()
  38. 44
  39. 45 if __name__ == "__main__":
  40. 46 linkstack1 = linkstack()
  41. 47 linkstack1.push(1)
  42. 48 linkstack1.push(2)
  43. 49 linkstack1.push(3)
  44. 50 linkstack1.push(4)
  45. 51 linkstack1.push(5)
  46. 52 linkstack1.push(6)
  47. 53 linkstack1.display()
  48. 54 print(linkstack1.gettop())
  49. 55 print(linkstack1.length())
  50. 56 linkstack1.pop()
  51. 57 linkstack1.display()
  52. 58 linkstack1.clear()
  53. 59 linkstack1.display()
  54. 60 print(linkstack1.isEmpty())

运行结果

6 5 4 3 2 1  
6

6

5 4 3 2 1  
None



True

代码逻辑较为简单所以代码没有注释,如果有什么地方不明白,欢迎留言!

python-实现链式栈的更多相关文章

  1. 基于python实现链式栈

    """ 链式栈 linkstack.py 思路分析: 1.源于链表结构 2.封装栈的操作方法(入栈,出栈,栈空,栈顶) 3.链表的开头作为栈顶(不用每次遍历,效率高,怎样 ...

  2. python中文语料分词处理,按字或者词cut_sentence

    cut_sentence.py import string import jieba import jieba.posseg as psg import logging #关闭jieba日制 jieb ...

  3. Python中的多进程与多线程(一)

    一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...

  4. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  5. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

  6. JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议

    软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...

  7. 可爱的豆子——使用Beans思想让Python代码更易维护

    title: 可爱的豆子--使用Beans思想让Python代码更易维护 toc: false comments: true date: 2016-06-19 21:43:33 tags: [Pyth ...

  8. 使用Python保存屏幕截图(不使用PIL)

    起因 在极客学院讲授<使用Python编写远程控制程序>的课程中,涉及到查看被控制电脑屏幕截图的功能. 如果使用PIL,这个需求只需要三行代码: from PIL import Image ...

  9. Python编码记录

    字节流和字符串 当使用Python定义一个字符串时,实际会存储一个字节串: "abc"--[97][98][99] python2.x默认会把所有的字符串当做ASCII码来对待,但 ...

  10. Apache执行Python脚本

    由于经常需要到服务器上执行些命令,有些命令懒得敲,就准备写点脚本直接浏览器调用就好了,比如这样: 因为线上有现成的Apache,就直接放它里面了,当然访问安全要设置,我似乎别的随笔里写了安全问题,这里 ...

随机推荐

  1. TCP之“3次握手,4次挥手”问题——实例分析

    上一篇我们分析了三次握手和四次握手的过程,但是理论分析难免枯燥难懂,下面这篇我们来看一个例子,就能更好地理解tcp链接了. 我们可以通过网络抓包的查看具体的流程: 比如我们服务器开启9502的端口.使 ...

  2. liunx命令二

    声明:以下资料全部摘自实验楼 常用快捷键 按键 作用 Table 补全命令 Ctrl+c 强制结束 Ctrl+d 键盘输入结束或退出终端 Ctrl+s 暂停当前程序,暂停后按下任意键恢复运行 Ctrl ...

  3. Vue dynamic component All In One

    Vue dynamic component All In One Vue 动态组件 vue 2.x https://vuejs.org/v2/guide/components-dynamic-asyn ...

  4. 同步vscode的setting.json和extensions

    vc 详情 $ npm i -g vscode-config $ vc config --token <your github token> $ vc config --id <yo ...

  5. 「NGK每日快讯」11.20日NGK公链第17期官方快讯!

  6. Hive安装与配置——2.3.5版本

    Hive安装配置 Hive是一个数据仓库基础工具在Hadoop中用来处理结构化数据.它架构在Hadoop之上,提供简单的sql查询功能,可以将sql语句转换为MapReduce任务进行运行,使查询和分 ...

  7. frame 和 iframe

    1.frame不能脱离frameSet单独使用,iframe可以: 2.frame不能放在body中:如下可以正常显示: <!--<body>--> <frameset ...

  8. python类的内部方法

    目录 一.绑定方法与非绑定方法 1.绑定方法 2.非绑定方法 二.property 1.什么是property? 2.为什么要用property? 3.如何使用property? 三.isinstan ...

  9. 生产者与消费者以及ActiveMQ

    生产者与消费者以及ActiveMQ 一. 多线程实现生产者与消费者 1.1 生产者与消费者头文件 #pragma once #include <iostream> #include < ...

  10. 40. 组合总和 II + 递归 + 回溯 + 记录路径

    40. 组合总和 II LeetCode_40 题目描述 题解分析 此题和 39. 组合总和 + 递归 + 回溯 + 存储路径很像,只不过题目修改了一下. 题解的关键是首先将候选数组进行排序,然后记录 ...