题目如下:你需要不借助其他任何数据结构,通过递归实现栈的逆序(我很想吐槽这个题,怎么会有人这么干?但是鉴于它的做法比较骚,所以还是写上记录一下)。
//弹出栈底元素static T popStackBack(stack& stk){//出栈T cur = stk.top();stk.pop();// 判空if (stk.empty()) return cur;// 递归T last = popStackBack(stk);//压栈stk.push(cur);//返回栈底return last;}
借助上面的这个方法,我们可以实现栈底元素的弹出,并保留当前栈其他元素的相对位置
实现思路类似于上面的操作,也是通过递归来保存每一层弹出的栈底元素,不过具体的实现方式有一些差别:
//逆序static void reverse(stack& stk){if (stk.empty()) return;T curBack = popStackBack(stk);reverse(stk);stk.push(curBack);}
最后我想说:这个空间复杂度都为O(N),时间复杂度O(N**2)的题没有任何实用价值,仅限于做题扩展思路,如果有不懂的话,写三个数字模拟一下,很快就搞懂了。