用递归函数进行栈的逆序

天下没有免费的午餐。这个题目来自于牛客网:http://www.nowcoder.com/773456



题目大意:给定一个栈,不用其他数据结构辅助,将栈内容逆序。

假设允许用其他数据结构,我们可以很快想到,用另外一个栈,将原栈内容“灌”到另一个栈里面即可。

但是左程云老师说,不允许。

递归的本质是栈的运用。所以我们可以借助递归让系统为我们创建这样一个“辅助栈”

Talk is cheap, here is the code:

 1 public static void reverseStack(Stack<Integer> stack){
 2         if(stack.isEmpty()) return;
 3         int temp = getBottomData(stack);
 4         reverseStack(stack);
 5         stack.push(temp);
 6     }
 7
 8     public static int getBottomData(Stack<Integer> stack){
 9         int res = stack.pop();
10         if(stack.isEmpty()){
11             return res;
12         }
13         int temp = getBottomData(stack);
14         stack.push(res);
15         return temp;
16     }

通过函数名即可知道这两个函数的作用。

核心函数是:getBottomData(Stack<Integer> stack),递归调用过程图示如下:

顺着递归的过程走下去,可以发现,getBottomData(Stack<Integer> stack)函数的功能就是返回栈的栈底元素,并使得原来的栈数据依次往栈底移动。

如上图所示,经过一次作用后,原栈[4, 3, 2 , 1]弹出了最底部的元素1,栈的长度减1。

接下来解释reverseStack(Stack<Integer> stack)函数。

此函数的递归思路比较简单,每层递归通过getBottomData()将栈底的元素取出来并缓存到变量中,直到栈空,然后开始逆向将每层变量值入栈,最后原栈中的数据得到了逆序存放。递归调用过程如下:



记录,总结,提升。

时间: 2024-11-07 23:28:06

用递归函数进行栈的逆序的相关文章

1.3 仅用递归函数和栈操作逆序一个栈

题目:一个栈依次压入1,2,3,4,5,那么从栈顶到栈底分别为5,4,3,2,1.将这个栈转置后,从栈顶到栈底为1,2,3,4,5,也就是实现栈中元素的逆序,但是只能用递归函数来实现,不能用其它数据结构. 1 //仅用递归函数和栈操作逆序一个栈 2 #include <stdio.h> 3 #include "stack.h" //该头文件包含栈操作的原型声明等相关信息 4 5 SqStack stack; 6 7 //获取栈底元素并删除 8 int getAndRemov

编程3:仅用递归函数和栈操作逆序一个栈

<?php header("content-type:text/html;charset=utf-8"); /* * 仅用递归函数和栈操作逆序一个栈 P8 */ function getAndRemoveLastElement(SplStack $stack){ if($stack->isEmpty()){ return false; } $value = $stack->pop(); if($stack->isEmpty()){ return $value;

[Daily]仅用递归函数和栈操作逆序一个栈

[题目] 一个栈依次压入1,2,3,4,5:那么从栈顶到栈底分别为5,4,3,2,1..将栈转置 [要求] 只能用递归函数来实现. [分析] 该算法需要两个递归函数.分别是getAndRemoveLastElement()和Reverse() 函数名 描述 getAndRemoveLastElement 将栈Stack的栈底元素返回并移除.作为中间步骤被Reverse使用 Reverse 算法的入口.主要功能为将栈顶元素优先压入栈中(放在栈底) 关于getAndRemoveLastElement

【栈】仅用递归函数和栈操作逆序一个栈

题目: 一个栈依次压入1.2.3.4.5,那么从栈顶到栈底分别为5.4.3.2.1.将这个栈转置后,从栈顶到栈底为1.2.3.4.5,也就是实现栈中元素的逆序.但是只能用递归函数来实现,不能用其他数据结构 题解: 需要两个递归函数:1. 将栈底元素返回并删除:2. 逆序一个栈 过程即为获取栈底元素,逆序2.3.4.5,递归后获取栈底元素2,逆序3.4.5,再次递归获取栈底元素3,逆序4.5,再次递归获取栈底元素4,逆序5,最后获取栈底元素5, 逆序空栈.依次返回插入获取的栈底元素,也就是依次插入

用递归函数和栈操作逆序栈

题目描述 一个栈依次压入1,2,3,4,5那么从栈顶到栈底分别为5,4,3,2,1.将这个栈转置后,从栈顶到栈底为1,2,3,4,5,也就是实现了栈中元素的逆序,请设计一个算法实现逆序栈的操作,但是只能用递归函数来实现,而不能用另外的数据结构. 给定一个栈Stack以及栈的大小top,请返回逆序后的栈. 测试样例: [1,2,3,4,5],5 返回:[5,4,3,2,1] Solution 1:思路:第一步,将最上面的数出栈保存,然后将栈逆序(递归) 第二步,将第一步中出栈的数插入到栈的最底层(

编写递归函数来使字符串逆序

题目内容: 编写函数来使一个字符串逆序输出,要求必须用递归函数. 输入格式: 一个字符串,不会超过100个字符长,中间可能包含空格 输出格式: 该字符串的逆序 输入样例: Hello,everyone 输出样例: enoyreve,olleH 程序代码:* #include<iostream> using namespace std;void reverse(char *s){ if(s[0]=='\0') return; else { reverse(&s[1]); cout<

仅用递归函数和栈操作逆序一个栈

要求: 一个栈依次压入1,2,3,4,5那么从栈顶到栈底分别为5,4,3,2,1.将这个栈转置后,从栈顶到栈底为1,2,3,4,5,也就是实现栈中元素的逆序,但是只能用递归函数来实现,而不能用另外的数据结构. import java.util.Stack; public class Problem03_ReverseStackUsingRecursive { /* * 递归得到栈底元素 */ public static int getAndRemoveLastElement(Stack<Inte

用递归函数和栈操作逆序一个栈

问题描述: 一个栈依次压入1,2,3,4,5那么从栈顶到栈底分别为5,4,3,2,1.将这个栈转置后,从栈顶到栈底为1,2,3,4,5,也就是实现栈中元素的逆序,但是只能用递归函数来实现,而不能用另外的数据结构. 实现代码: #include <stack> #include <stdio.h> using namespace std; int GetAndRemoveBottom(stack<int> &ss) { int top, bottom; top =

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

[题目]? 一个栈依次压入1.2.3.4.5,那么从栈顶到栈底分别为5.4.3.2.1.将这个栈转置后,从栈顶到栈底为1.2.3.4.5,也就是实现栈中元素的逆序,但是只能用递归函数来实现,不能用其他的数据结构. [解答] ?首先分为两步.第一步,得到栈底元素并移除这个栈底元素:第二步,将得到的栈底元素逆序入栈. [代码] 1 package cn.hl.p3; 2 3 import java.util.Stack; 4 5 /** 6 * title:一个栈依次压入1.2.3.4.5, 7 *