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

题目

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

思路

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

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

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

主流程

可以先理解 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()函数的流程。

相关推荐
千寻技术帮几秒前
10333_基于SpringBoot的家电进存销系统
java·spring boot·后端·源码·项目·家电进存销
dear_bi_MyOnly几秒前
【多线程——线程状态与安全】
java·开发语言·数据结构·后端·中间件·java-ee·intellij-idea
jiaguangqingpanda7 分钟前
Day36-20260204
java·开发语言
ctyshr12 分钟前
C++编译期数学计算
开发语言·c++·算法
tb_first13 分钟前
万字超详细苍穹外卖学习笔记4
java·spring boot·笔记·学习·spring·mybatis
zh_xuan21 分钟前
最小跳跃次数
数据结构·算法
努力写代码的熊大30 分钟前
c++异常和智能指针
java·开发语言·c++
yumgpkpm31 分钟前
2026软件:白嫖,开源,外包,招标,晚进场(2025年下半年),数科,AI...中国的企业软件产业出路
大数据·人工智能·hadoop·算法·kafka·开源·cloudera
山岚的运维笔记34 分钟前
SQL Server笔记 -- 第15章:INSERT INTO
java·数据库·笔记·sql·microsoft·sqlserver
Yvonne爱编码34 分钟前
JAVA数据结构 DAY5-LinkedList
java·开发语言·python