双栈排序练习
来源:互联网 发布:淘宝上没有燕尾型材了 编辑:程序博客网 时间:2024/06/05 12:49
请编写一个程序,按升序对栈进行排序(即最大元素位于栈顶),要求最多只能使用一个额外的栈存放临时数据,但不得将元素复制到别的数据结构中。
给定一个int[] numbers(C++中为vector),其中第一个元素为栈顶,请返回排序后的栈。请注意这是一个栈,意味着排序过程中你只能访问到第一个元素。
测试样例:
[1,2,3,4,5]
返回:[5,4,3,2,1]
思路非常简单,利用一个辅助栈,每次比较排序栈和辅助栈的顶元素,如果排序栈较小直接压入辅助栈,并弹出排序栈,否则将辅助栈的元素弹出并压在排序栈栈顶元素的后面。知道排序栈没有元素了,之后将辅助栈的元素全部导入排序栈,就完成排序。
class TwoStacks {public: vector<int> twoStacksSort(vector<int> numbers) { stack<int> mystack,help; for(auto i=numbers.end()-1;i>=numbers.begin();--i) mystack.push(*i); while(!mystack.empty()) { if(help.empty()){ help.push(mystack.top()); mystack.pop(); } else if(mystack.top()<=help.top()) { help.push(mystack.top()); mystack.pop(); } else { int temp=mystack.top(); mystack.pop(); mystack.push(help.top()); mystack.push(temp); help.pop(); } } while(!help.empty()) { mystack.push(help.top()); help.pop(); } for(auto &c:numbers) { c=mystack.top(); mystack.pop(); } return numbers; }};
0 0
- 双栈排序练习
- 双栈排序练习
- 图论练习2:双栈排序
- 练习排序
- 排序练习
- 数字雨+大数加法+割圆术求π+冒泡排序+快速排序+栈练习+链表练习
- 排序练习(归并排序)
- c++ 选择排序 练习
- 数据结构练习:排序
- 数据结构练习:排序
- 数据结构练习:快速排序
- [算法练习] 冒泡排序
- jquery排序 练习
- 直接插入排序 练习
- 折半插入排序 练习
- 简单选择排序练习
- 冒泡排序练习
- 内部排序算法练习
- Oracle相关压缩技术
- 修改Spring中MaxUploadSizeExceededException返回提示
- python学习:zip函数
- 【Java EE】JDBC数据库编程基础
- Mybatis学习之Mapper工具实践
- 双栈排序练习
- C# 时间格式
- mysql 表设计,约束条件,索引
- linux c之((void *) - 1)是啥意思
- 如何理解 RxJS?
- 怎样写权利要求书(转)
- Pentester Lab学习计划之From SQL Injection to Shell II
- 基于.net的分布式事务
- Spring基于xml的定时器配置