bitriniterator.java

来自「基本的数据结构的java代码」· Java 代码 · 共 46 行

JAVA
46
字号
public class BiTrInIterator extends BiTreeInterator{
	private LinStack s = new LinStack();
	
	BiTrInIterator(BiTreeNode t){
		super(t);
	}
	
	private BiTreeNode goFarLeft(BiTreeNode t){
		if(t == null) return null;
		while(t.getLeft() != null){
			s.push(t);
			t = t.getLeft();
		}
		return t;
	}
	
	public void reset(){
		if(root == null)
			 iteComplete = 1;	 
		else iteComplete = 0;
		
		if (root == null) return;
		current = goFarLeft(root);
	}
	
	public void next(){
		if(iteComplete == 1){
			System.out.println("已到二叉树尾!");
			return;
		}
		
		if(current.getRight() != null){
			current = goFarLeft(current.getRight());
		}
		else if(! s.isEmpty()){
			try{
				current = (BiTreeNode)s.pop();
			}
			catch(Exception e){
				e.printStackTrace();
			}
		}
		else
			iteComplete = 1;
	}
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?