C++使用递归函数和栈操作逆序一个栈的算法示例
2019/7/10 22:47:54
本文主要是介绍C++使用递归函数和栈操作逆序一个栈的算法示例,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
本文实例讲述了C++使用递归函数和栈操作逆序一个栈的算法。分享给大家供大家参考,具体如下:
题目:
一个栈依次压入1、2、3、4、5,那么栈顶到栈底分别为:5、4、3、2、1。
将这个栈逆置后栈顶到栈底分别为1、2、3、4、5。
用递归函数来实现,不能用其他数据结构。
解题思路及代码
1、递归函数一:将栈的栈底元素一个个返回并移除。
2、递归函数二:逆序栈,调用递归函数一实现。
C++实现:
class Solution { public: //递归函数一 static int getAndRemoveStackLastElem(stack<int>& s) { int result = s.top(); s.pop(); if (s.empty()) return result; else { int last = getAndRemoveStackLastElem(s); s.push(result); return last; } } //递归函数二 static void reverseStack(stack<int>& s) { if (s.empty()) return; int i = getAndRemoveStackLastElem(s); reverseStack(s); s.push(i); } };
程序测试用例:
#include <iostream> #include <stack> using namespace std; class Solution { public: static int getAndRemoveStackLastElem(stack<int>& s) { int result = s.top(); s.pop(); if (s.empty()) return result; else { int last = getAndRemoveStackLastElem(s); s.push(result); return last; } } static void reverseStack(stack<int>& s) { if (s.empty()) return; int i = getAndRemoveStackLastElem(s); reverseStack(s); s.push(i); } }; //打印栈 void show(stack<int> s) { while (!s.empty()) { cout << s.top() << " "; s.pop(); } cout << endl; } int main() { stack<int> s; s.push(1); s.push(2); s.push(3); s.push(4); s.push(5); s.push(6); cout << "Before reverse: " << endl; show(s); cout << "After reverse: " << endl; Solution::reverseStack(s); show(s); system("pause"); }
运行结果:
Before reverse: 6 5 4 3 2 1 After reverse: 1 2 3 4 5 6 请按任意键继续. . .
希望本文所述对大家C++程序设计有所帮助。
这篇关于C++使用递归函数和栈操作逆序一个栈的算法示例的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享