您的位置:首页 > 其它

只利用一个额外栈实现栈的排序

2016-11-14 17:08 232 查看
package chapter01_stack_and_queue;

import java.util.Stack;

public class _05_StackSortStack {
public static void sortStackByStack(Stack<Integer> stack) {
Stack<Integer> stackHelp = new Stack<Integer>();
while(!stack.isEmpty()) {
int cur = stack.pop();
while(!stackHelp.isEmpty() && stackHelp.peek() < cur) {
stack.push(stackHelp.pop());
}
stackHelp.push(cur);
}
while (!stackHelp.isEmpty()) {
stack.push(stackHelp.pop());
}
}

public static void main(String[] args) {
Stack<Integer> stack = new Stack<Integer>();
stack.push(3);
stack.push(1);
stack.push(6);
stack.push(2);
stack.push(5);
stack.push(4);
sortStackByStack(stack);
System.out.println(stack.pop());
System.out.println(stack.pop());
System.out.println(stack.pop());
System.out.println(stack.pop());
System.out.println(stack.pop());
System.out.println(stack.pop());
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  排序
相关文章推荐