请编写一个程序,按升序对栈进行排序(即最大元素位于栈顶),要求最多只能使用一个额外的栈存放临时数据,但不得将元素复制到别的数据结构中。 给定一个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; }};新闻热点
疑难解答