栈的运算(浏览器页面的退出与前进)————之极客时间笔记2

编译器就是通过两个栈来实现的。其中一个保存操作数的栈,另一个是保存运算符的栈。
我们从左向右遍历表达式,当遇到数字,我们就直接压入操作数栈;当遇到运算符,就与运算符栈的栈顶元素进行比较。如果比运算符栈顶元素的优先级高,就将当前运算符压入栈;

☆ 如果比运算符栈顶元素的优先级低或者相同,从运算符栈中取栈顶运算符,从操作数栈的栈顶取 2 个操作数,然后进行计算,再把计算完的结果压入操作数栈,继续比较。

栈的运算(浏览器页面的退出与前进)————之极客时间笔记2_第1张图片

如何实现浏览器的前进、后退功能?其实,用两个栈就可以非常完美地解决这个问题。

栈的运算(浏览器页面的退出与前进)————之极客时间笔记2_第2张图片
栈的运算(浏览器页面的退出与前进)————之极客时间笔记2_第3张图片

栈的运算(浏览器页面的退出与前进)————之极客时间笔记2_第4张图片

我们在讲栈的应用时,讲到用函数调用栈来保存临时变量,为什么函数调用要用“栈”来保存临时变量呢?用其他数据结构不行吗?

答:因为函数调用的执行顺序符合后进者先出,先进者后出的特点。比如函数中的局部变量的生命周期的长短是先定义的生命周期长,后定义的生命周期短;还有函数中调用函数也是这样,先开始执行的函数只有等到内部调用的其他函数执行完毕,该函数才能执行结束。
正是由于函数调用的这些特点,根据数据结构是特定应用场景的抽象的原则,我们优先考虑栈结构。

你可能感兴趣的:(栈)