目录

暴力递归练习(三)— 逆序栈

题目

给你一个栈,如何在不申请额外的数据结构下,只能使用递归函数,将栈逆序?

思路

根据栈的特性,先进后出、后进先出,那我是不是获取到栈底的元素后,再进行压栈操作,栈就可以逆序。

那如何能获取栈底的元素呢?这时候就需要黑盒思想

如果我有一个方法,每次都可以获取到栈底元素,那我当我递归调用时,将获取到的栈底元素重新压回栈,是不是就可以完成栈的逆序了。

主流程

可以先理解 f() 就是个黑盒的方法,每次调用都可以获得栈底的元素,那主流程reverse方法递归调用时,(栈中元素 栈底 -> 栈顶 1 -> -2 > 3),每次调用 f() 方法,依次获取,1 -> 2 -> 3,等到stack.isEmpty(),开始return,向上传递,那依次得到的就是 3 -> 2 -> 1,在依次压入栈即可。

java 复制代码
public static void reverse(Stack<Integer> stack) {
        if (stack.isEmpty()) {
            return;
        }
        int i = f(stack);
        reverse(stack);
        stack.push(i);
    }

主流程已经完成,接下来就是实现黑盒方法 f() 函数。

黑盒方法

f() 方法的整体思想就是,如果stack不为 null, 则递归获取,当获取到栈底元素后,stack为null, 则向上回弹,将获取到的非栈底元素再按照原有顺序压回去,并返回栈底元素。

java 复制代码
public static Integer f(Stack<Integer> stack) {
        int result = stack.pop();
        if (stack.isEmpty()) {
            return result;
        } else {
            int last = f(stack);
            stack.push(result);
            return last;
        }
    }

f函数执行流程

利用了2个递归,可以先将f()函数当做黑盒函数,主流程完成后,实现f()函数的流程。

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
阳洞洞37 分钟前
leetcode 139. Word Break
算法·leetcode·word·动态规划
向哆哆37 分钟前
Java 测试框架:JUnit 5 的新特性与最佳实践
java·数据库·junit
try to be better_fly38 分钟前
buctoj_算法设计与分析(5)
算法
forestsea38 分钟前
WebFlux应用中获取x-www-form-urlencoded数据的六种方法
java·java-ee·webflux
云边有个稻草人2 小时前
思维与算法共舞:AIGC语言模型的艺术与科学
开发语言·算法·什么是语言模型?·多任务学习与多模态生成·客户服务与聊天机器人·自适应生成与定制化文本·预训练与微调
pzx_0012 小时前
【深度学习】自定义实现DataSet和DataLoader
开发语言·人工智能·python·深度学习·算法
Bonnie_12155 小时前
07-算法打卡-链表-移除链表-leetcode(203)-第七天
算法·leetcode·链表
Tracy-226 小时前
啥是Spring,有什么用,既然收费,如何免费创建SpringBoot项目,依赖下载不下来的解决方法,解决99%问题!
java·spring
未定义.2216 小时前
Java设计模式实战:策略模式在SimUDuck问题中的应用
java·设计模式·策略模式
槐月杰7 小时前
入门到精通,C语言十大经典程序
c语言·数据结构·算法