题目:将一个栈中的元素排序,借助另外一个栈!
思路:将排序的栈每次出栈一个元素,第一次直接放入缓冲栈中,第二开始直至结束,每个出栈元素都需要跟缓冲栈里面元素比较找到排序位置(缓冲栈这个时候也需要吐栈可以考虑把元素放回到排序栈中待会再放回来),直到所有元素排序完毕。
#include <iostream>
#include <stack>
void sortStack(stack<int>& InputStack)
{
stack<int> Help;//定义一个暂时缓冲栈
while (!InputStack.empty())
{
int CurValue = InputStack.top();
InputStack.pop();
while (!Help.empty() && CurValue > help.top())//在另外栈里面寻找插入位置
{
InputStack.push(Help.top());
Help.pop();
}
Help.push(CurValue );
}
while (!Help.empty())//再把反序元素放回到原栈中
{
int Val = Help.top();
InputStack.push(Val);
Help.pop();
}
}
在VS2015,中间(第二行)输出为缓冲栈结果,测试结果如下:


1954

被折叠的 条评论
为什么被折叠?



