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

枫铃4年前 (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同步windows和linux文件

写python脚本的初衷,每次在windows编辑完文件后,想同步到linux上去,只能够登录服务器,...

爬虫基本原理

爬虫基本原理 一、爬虫是什么? 百度百科和维基百科对网络爬虫的定义:简单来说爬虫就是抓取目标网站内容的工具,一般是根据定义的行...

Django 函数和方法的区别

函数和方法的区别 1、函数要手动传self,方法不用传 2、如果是一个函数,用类名去调用,如果是一个方法...

Django 知识补漏单例模式

单例模式:(说白了就是)创建一个类的实例。在 Python 中,我们可以用多种方法来实现单例模式&#x...

Django基础知识MTV

Django简介 Django是使用Python编写的一个开源Web框架。可以用它来快速搭建一个高性能的网站。 Django也是一个MVC框架。但是在Dj...

Python mysql 索引原理与慢查询优化

一 介绍 为何要有索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,...

发表评论

访客

看不清,换一张

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