敲代码将一个栈按升序排序。
附加栈来实现:
另外一种算法有个极端的測试列子:假设原来栈的数据底部到顶部是从小到大的。比如:
1 2 3 4 5 6 7
那么Tmp每次push一个不同的数就要清空栈中的全部数据。比方某时刻
vStk:1 2 3 4 5
Tmp:6 7
当Tmp要push 5的时候就要清空6 7,然后在push5,这时候vStk栈的数据添加:
vStk: 1 2 3 4 7 6
Tmp: 5
对这个栈是怎样实现的,你不应该做不论什么特殊的如果。
程序中能用到的栈操作有:push | pop |isEmpty
最easy想到的就是优先队列来做此题。easy实现。
另外我们能够再用一个栈来实现栈的升序排列。
优先队列:
//优先队列来实现 void sortStack(std::stack<int>& vStk) { std::priority_queue<int, std::vector<int>, std::greater<int>> Queue; while (!vStk.empty()) { Queue.push(vStk.top()); vStk.pop(); } while (!Queue.empty()) { vStk.push(Queue.top()); Queue.pop(); } }
附加栈来实现:
//附加一个栈来实现 void sortStack_(std::stack<int>& vStk) { std::stack<int> Tmp; while (!vStk.empty()) { int Top = vStk.top(); vStk.pop(); while (!Tmp.top() && Top < Tmp.top()) { vStk.push(Tmp.top()); Tmp.pop(); } Tmp.push(Top); } }
另外一种算法有个极端的測试列子:假设原来栈的数据底部到顶部是从小到大的。比如:
1 2 3 4 5 6 7
那么Tmp每次push一个不同的数就要清空栈中的全部数据。比方某时刻
vStk:1 2 3 4 5
Tmp:6 7
当Tmp要push 5的时候就要清空6 7,然后在push5,这时候vStk栈的数据添加:
vStk: 1 2 3 4 7 6
Tmp: 5