2013-03-19 15:55:33 +11:00

248 lines
3.3 KiB
JavaScript

//>>built
define("dojox/collections/BinaryTree",["dojo/_base/kernel","dojo/_base/array","./_base"],function(_1,_2,_3){
_3.BinaryTree=function(_4){
function _5(_6,_7,_8){
this.value=_6||null;
this.right=_7||null;
this.left=_8||null;
this.clone=function(){
var c=new _5();
if(this.value.value){
c.value=this.value.clone();
}else{
c.value=this.value;
}
if(this.left!=null){
c.left=this.left.clone();
}
if(this.right!=null){
c.right=this.right.clone();
}
return c;
};
this.compare=function(n){
if(this.value>n.value){
return 1;
}
if(this.value<n.value){
return -1;
}
return 0;
};
this.compareData=function(d){
if(this.value>d){
return 1;
}
if(this.value<d){
return -1;
}
return 0;
};
};
function _9(_a,a){
if(_a){
_9(_a.left,a);
a.push(_a.value);
_9(_a.right,a);
}
};
function _b(_c,_d){
var s="";
if(_c){
s=_c.value.toString()+_d;
s+=_b(_c.left,_d);
s+=_b(_c.right,_d);
}
return s;
};
function _e(_f,sep){
var s="";
if(_f){
s=_e(_f.left,sep);
s+=_f.value.toString()+sep;
s+=_e(_f.right,sep);
}
return s;
};
function _10(_11,sep){
var s="";
if(_11){
s=_10(_11.left,sep);
s+=_10(_11.right,sep);
s+=_11.value.toString()+sep;
}
return s;
};
function _12(_13,_14){
if(!_13){
return null;
}
var i=_13.compareData(_14);
if(i==0){
return _13;
}
if(i>0){
return _12(_13.left,_14);
}else{
return _12(_13.right,_14);
}
};
this.add=function(_15){
var n=new _5(_15);
var i;
var _16=_17;
var _18=null;
while(_16){
i=_16.compare(n);
if(i==0){
return;
}
_18=_16;
if(i>0){
_16=_16.left;
}else{
_16=_16.right;
}
}
this.count++;
if(!_18){
_17=n;
}else{
i=_18.compare(n);
if(i>0){
_18.left=n;
}else{
_18.right=n;
}
}
};
this.clear=function(){
_17=null;
this.count=0;
};
this.clone=function(){
var c=new _3.BinaryTree();
var itr=this.getIterator();
while(!itr.atEnd()){
c.add(itr.get());
}
return c;
};
this.contains=function(_19){
return this.search(_19)!=null;
};
this.deleteData=function(_1a){
var _1b=_17;
var _1c=null;
var i=_1b.compareData(_1a);
while(i!=0&&_1b!=null){
if(i>0){
_1c=_1b;
_1b=_1b.left;
}else{
if(i<0){
_1c=_1b;
_1b=_1b.right;
}
}
i=_1b.compareData(_1a);
}
if(!_1b){
return;
}
this.count--;
if(!_1b.right){
if(!_1c){
_17=_1b.left;
}else{
i=_1c.compare(_1b);
if(i>0){
_1c.left=_1b.left;
}else{
if(i<0){
_1c.right=_1b.left;
}
}
}
}else{
if(!_1b.right.left){
if(!_1c){
_17=_1b.right;
}else{
i=_1c.compare(_1b);
if(i>0){
_1c.left=_1b.right;
}else{
if(i<0){
_1c.right=_1b.right;
}
}
}
}else{
var _1d=_1b.right.left;
var _1e=_1b.right;
while(_1d.left!=null){
_1e=_1d;
_1d=_1d.left;
}
_1e.left=_1d.right;
_1d.left=_1b.left;
_1d.right=_1b.right;
if(!_1c){
_17=_1d;
}else{
i=_1c.compare(_1b);
if(i>0){
_1c.left=_1d;
}else{
if(i<0){
_1c.right=_1d;
}
}
}
}
}
};
this.getIterator=function(){
var a=[];
_9(_17,a);
return new _3.Iterator(a);
};
this.search=function(_1f){
return _12(_17,_1f);
};
this.toString=function(_20,sep){
if(!_20){
_20=_3.BinaryTree.TraversalMethods.Inorder;
}
if(!sep){
sep=",";
}
var s="";
switch(_20){
case _3.BinaryTree.TraversalMethods.Preorder:
s=_b(_17,sep);
break;
case _3.BinaryTree.TraversalMethods.Inorder:
s=_e(_17,sep);
break;
case _3.BinaryTree.TraversalMethods.Postorder:
s=_10(_17,sep);
break;
}
if(s.length==0){
return "";
}else{
return s.substring(0,s.length-sep.length);
}
};
this.count=0;
var _17=this.root=null;
if(_4){
this.add(_4);
}
};
_3.BinaryTree.TraversalMethods={Preorder:1,Inorder:2,Postorder:3};
return _3.BinaryTree;
});