题目描述:
一个栈依次压入1,2,3,4,5,那么从栈顶到栈底分别为5,4,3,2,1。将这个栈转置后,从栈顶到栈底为1,2,3,4,5,也就是实现栈中元素的逆序,但是只能用递归函数来实现,不能用其他数据结构。
输入描述:
输入数据第一行一个整数N为栈中元素的个数。
接下来一行N个整数
X
i
X_i
Xi表示从栈顶依次到栈底的每个元素。
输出描述:
输出一行表示栈中元素逆序后的每个元素
示例1
输入
5
1 2 3 4 5
输出
5 4 3 2 1
题解:
这题比较烦人,如果只是为了过题的话,直接将输入逆序输出就行,但是题目要求只能递归,那行吧,开整。。。
我们需要两个递归函数,一个是获取栈底元素并删除的函数,一个是逆序函数,也就是题目要求实现的函数。
具体的看代码吧,倒来倒去的。。。
代码:
#include <cstdio>
using namespace std;
const int N = 100010;
int stk[N];
int top;
int getAndRemoveLastElement() {
int result = stk[top--];
if (top < 0) return result;
else {
int last = getAndRemoveLastElement();
stk[++top] = result;
return last;
}
}
void reverseStack() {
if (top < 0) return;
int last = getAndRemoveLastElement();
reverseStack();
stk[++top] = last;
}
int main(void) {
int n, val;
scanf("%d", &n);
top = n - 1;
while (n) scanf("%d", &stk[--n]);
reverseStack();
for (int i = top; i >= 0; --i) printf("%d%c", stk[i], " \n"[!i]);
return 0;
}