![1f29cc4b8967676995379cc146cada17.gif](https://i-blog.csdnimg.cn/blog_migrate/0e1d79bc2bb5f3f1a3d961f1dde315e7.gif)
![ddd9535cea66b036e507a891d5eccd58.png](https://i-blog.csdnimg.cn/blog_migrate/ba560082b6bb1fbf00ee4623cb1bb454.jpeg)
栈
![268248cc00ee214546a31f2156fc724f.png](https://i-blog.csdnimg.cn/blog_migrate/bfcf871ae9437599634f3de55ac69034.jpeg)
栈的示意图
1、什么是栈(stack)呢?
@Python大星 作为一个吃货,把“栈”想象是一摞迭在一起的大饼,在放饼的时候,需要自下而上一个一个放,拿饼的时候需要自上而下一个一个拿。
![00072905c586ff82d66eb57722670170.png](https://i-blog.csdnimg.cn/blog_migrate/ccabeec8b3bb2e5492e0bdd75d8cef32.jpeg)
栈的数据结构:
① 先进后出,后进先出
② 只能在一端进行插入和删除操作
2、 栈的应用场景
① 栈在表达式求值中的使用
3+4*5-6=?
分为 2 个栈,1 个存储数字的栈,1 个 存储运算符的栈。
表达式从左到右遍历表达式,遇到数组就压入操作数栈,遇到运算符,就将运算符栈的栈顶数据做比较。
如果运算符优先级高于运算符栈栈顶元素,就将运算符入栈。如果低于,就将栈顶元素取出,同事从操作数栈中取出两个元素进行运算,并将运算结果压入操作数栈。
![76e7a5e4b51e1f9dbc992efa2aa966d7.png](https://i-blog.csdnimg.cn/blog_migrate/a1df4d253a1746b2a87b0acf14b8e011.jpeg)
② 栈在函数中的使用
![6fc2710041e6d2ff85fd30135903a50b.png](https://i-blog.csdnimg.cn/blog_migrate/daec96f9e72af5f1a5518c649426fdee.jpeg)
![111b07a1ebe77a76caccf14682de6597.png](https://i-blog.csdnimg.cn/blog_migrate/df7f5b7045c66f626fc97f3e34eb99b7.jpeg)
● 当调用 greet("Python 大星"),计算机为该函数调用分配一块内存
![2fffd93e9647258707cb77bfed48d519.png](https://i-blog.csdnimg.cn/blog_migrate/47555fd775bc69424b6409304ed9d807.jpeg)
变量name被设置为Python大星,需要存储到内存中
● 打印 hello, Python 大星! 再调用 greet2("Python大星")
![ae42306709d79c7fa1a8e52f5d355cb2.png](https://i-blog.csdnimg.cn/blog_migrate/4969b5de5c96bc013f0c1c6a2fa5e41a.jpeg)
计算机使用一个栈来表示这些内存块,其中第二个内存块位于第一个内存块上面。打印 how are you,Python 大星? ,然后greet2调用返回,此时栈顶的内存块被弹出。
![0cd6f3c4242b8cb2f1c926b008cd4855.png](https://i-blog.csdnimg.cn/blog_migrate/36a1d9dda7e240cdd246115088efb36a.jpeg)
● 打印 getting ready to say bye,再调用函数 bye
![cb9b4b669152753043dd871a1741b7ab.png](https://i-blog.csdnimg.cn/blog_migrate/d7a7cfcab7d76362983ee4a22c1b550c.jpeg)
打印 ok bye!并从 bye 函数返回
![17c2b6f7acb3c84165be09cca7c3d667.png](https://i-blog.csdnimg.cn/blog_migrate/c705d646c77a91c2d19c8f49aa8ab829.jpeg)
● 回到函数 greet ,无其他事情要做,从函数 greet 返回
>>> Python 算法 04-- 选择排序的奥秘