python取出数组中每5个中的前4个_Python 算法 05 -- 3+4*5-6=?在栈中的调用

1f29cc4b8967676995379cc146cada17.gif
ddd9535cea66b036e507a891d5eccd58.png

268248cc00ee214546a31f2156fc724f.png

栈的示意图

1、什么是栈(stack)呢?

@Python大星 作为一个吃货,把“栈”想象是一摞迭在一起的大饼,在放饼的时候,需要自下而上一个一个放,拿饼的时候需要自上而下一个一个拿。

00072905c586ff82d66eb57722670170.png

栈的数据结构:

① 先进后出,后进先出

② 只能在一端进行插入和删除操作

2、 栈的应用场景

① 栈在表达式求值中的使用

3+4*5-6=?

分为 2 个栈,1 个存储数字的栈,1 个 存储运算符的栈。

表达式从左到右遍历表达式,遇到数组就压入操作数栈,遇到运算符,就将运算符栈的栈顶数据做比较。

如果运算符优先级高于运算符栈栈顶元素,就将运算符入栈。如果低于,就将栈顶元素取出,同事从操作数栈中取出两个元素进行运算,并将运算结果压入操作数栈。

76e7a5e4b51e1f9dbc992efa2aa966d7.png

② 栈在函数中的使用

6fc2710041e6d2ff85fd30135903a50b.png
111b07a1ebe77a76caccf14682de6597.png

● 当调用 greet("Python 大星"),计算机为该函数调用分配一块内存

2fffd93e9647258707cb77bfed48d519.png

变量name被设置为Python大星,需要存储到内存中

● 打印 hello, Python 大星! 再调用 greet2("Python大星")

ae42306709d79c7fa1a8e52f5d355cb2.png

计算机使用一个栈来表示这些内存块,其中第二个内存块位于第一个内存块上面。打印 how are you,Python 大星? ,然后greet2调用返回,此时栈顶的内存块被弹出。

0cd6f3c4242b8cb2f1c926b008cd4855.png

● 打印 getting ready to say bye,再调用函数 bye

cb9b4b669152753043dd871a1741b7ab.png

打印 ok bye!并从 bye 函数返回

17c2b6f7acb3c84165be09cca7c3d667.png

● 回到函数 greet ,无其他事情要做,从函数 greet 返回


>>> Python 算法 04-- 选择排序的奥秘

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值