双栈排序练习

来源:互联网 发布:淘宝上没有燕尾型材了 编辑:程序博客网 时间: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
原创粉丝点击