美文网首页
如何仅用递归函数和栈操作逆序一个栈(不用额外空间)

如何仅用递归函数和栈操作逆序一个栈(不用额外空间)

作者: 敲一手烂代码 | 来源:发表于2016-09-21 12:47 被阅读20次
int getStackBottomDate(Stack<Integer> stack) {
        int result = stack.pop();
        if (stack.isEmpty()) {
            return result;
        } else {
            int last = getStackBottomDate(stack);
            stack.push(result);
            return last;
        }
    }
    
    void reverseStack(Stack<Integer> stack) {
        if (stack.isEmpty()) {
            return;
        }
        int res = getStackBottomDate(stack);
        reverseStack(stack);
        stack.push(res);
    }

相关文章

网友评论

      本文标题:如何仅用递归函数和栈操作逆序一个栈(不用额外空间)

      本文链接:https://www.haomeiwen.com/subject/hlkaettx.html