Python:如何仅用递归函数和栈操作逆序一个栈

枫铃3年前 (2021-07-09)Python253
  • 如何仅用递归函数和栈操作逆序一个栈
  • 题目:
  • 一个栈依次压入1,2,3,4,5,那么从栈顶到栈底分别为5,4,3,2,1。
  • 将这个栈转置后,从栈顶到栈底为1,2,3,4,5,也就是实现栈中元素的逆序,
  • 但是只能用递归函数来实现,不能用其他数据结构。

方法一:

既然是递归,第一反应是采用两个栈实现该功能实现,依次弹出栈顶元素,然后压入另外一个栈中,代码如下:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 寻找有志同道合的小伙伴,
互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import java.util.Stack;
   
public class StackReverse0 {
    private Stack<Integer> stack0;
    private Stack<Integer> stack1;
    
    public StackReverse0(){
        stack0 = new Stack<Integer>();
        stack1 = new Stack<Integer>();
    }
    public void getLastElement(){
        Integer pop = stack0.pop();
        stack1.push(pop);
        if(!stack0.isEmpty())
            getLastElement();
    }
    
    public static void main(String[] args) {
        StackReverse0 sr = new StackReverse0();
        sr.stack0.add(1);
        sr.stack0.add(2);
        sr.stack0.add(3);
        sr.stack0.add(4);
        sr.stack0.add(5);
        
        sr.getLastElement();
        
        System.out.println(sr.stack1.pop());
        System.out.println(sr.stack1.pop());
        System.out.println(sr.stack1.pop());
        System.out.println(sr.stack1.pop());
        System.out.println(sr.stack1.pop());
    }
} 

方法2:类似两个stack的思路,不过是使用一个stack搞定。

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 寻找有志同道合的小伙伴,
互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import java.util.Stack;
public class StackReverse {
    public static int getAndRemoveLastElement(Stack<Integer> stack){ //负责删除stack bottom的一个元素,并返回
        int result = stack.pop();
        if(stack.isEmpty()){
            return result;
        }else{
            int last = getAndRemoveLastElement(stack);
            stack.push(result);  // stack还原
            return last;
        }
    }
    
    public static void reverse(Stack<Integer> stack){
        if(stack.isEmpty()){
            return;
        }
        int i = getAndRemoveLastElement(stack);
        reverse(stack);
        stack.push(i); // 效果就是依次将stack top的元素入栈,最后效果就是stack元素逆序
    }
    
    public static void main(String[] args) {
        Stack<Integer> stack = new Stack<Integer>();
        stack.push(1);
        stack.push(2);
        stack.push(3);
        stack.push(4);
        stack.push(5);
        reverse(stack);
        System.out.println(stack.pop());
        System.out.println(stack.pop());
        System.out.println(stack.pop());
        System.out.println(stack.pop());
        System.out.println(stack.pop());
    }
} 

相关文章

Python 定时任务的实现方式

Python 定时任务的实现方式

背景 目前所在的项目组需要经常执行一些定时任务,于是选择使用 Python 的定时器。 Python 实现定时任务 循环 sleep 这种...

Python集合list,tuple,dict,set

Python四中集合list,tuple,dict,set list(有数组越界问题) 创建list࿱...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。