![程序员代码面试指南:IT名企算法与数据结构题目最优解(第2版)](https://wfqqreader-1252317822.image.myqcloud.com/cover/650/25462650/b_25462650.jpg)
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
如何仅用递归函数和栈操作逆序一个栈
【题目】
一个栈依次压入1、2、3、4、5,那么从栈顶到栈底分别为5、4、3、2、1。将这个栈转置后,从栈顶到栈底为 1、2、3、4、5,也就是实现栈中元素的逆序,但是只能用递归函数来实现,不能用其他数据结构。
【难度】
尉 ★★☆☆
【解答】
本题考查栈的操作和递归函数的设计,我们需要设计出两个递归函数。
递归函数一:将栈stack的栈底元素返回并移除。
具体过程就是如下代码中的getAndRemoveLastElement方法。
![](https://epubservercos.yuewen.com/215615/13916128905952306/epubprivate/OEBPS/Images/22_2.jpg?sign=1739299289-GS0wcUkfUkhPjxiaYa6tZJD1c5RrAZB9-0-66ca20e66d67595494616f494d43e6b4)
如果从stack的栈顶到栈底依次为3、2、1,这个函数的具体过程如图1-4所示。
![](https://epubservercos.yuewen.com/215615/13916128905952306/epubprivate/OEBPS/Images/23_1.jpg?sign=1739299289-zZa6DYBYK5mM3pgBwmmAX86vfgpE2Nj7-0-eb5e7f40f668d542f766ad2f7ad9bb17)
图1-4
递归函数二:逆序一个栈,就是题目要求实现的方法,具体过程就是如下代码中的reverse方法。该方法使用了上面提到的getAndRemoveLastElement方法。
![](https://epubservercos.yuewen.com/215615/13916128905952306/epubprivate/OEBPS/Images/23_2.jpg?sign=1739299289-gzVVSN4f6wDsn7LxFFgs9xOUz9F0c1gk-0-9ca4ee5f363605a0df17b03f1e25530c)
如果从stack的栈顶到栈底依次为3、2、1,reverse函数的具体过程如图1-5所示。
![](https://epubservercos.yuewen.com/215615/13916128905952306/epubprivate/OEBPS/Images/23_3.jpg?sign=1739299289-EWf3ElSeFb6A1z5ym91SWC5SYfmjKkdR-0-ef6d2068f0446cc1651b172bd1a9022b)
图1-5
getAndRemoveLastElement方法在图中简单表示为get方法,表示移除并返回当前栈底元素。