|
1 | 1 | " |
2 | | -I represent Node for BST |
| 2 | +I represent a node for Binary Search Tree. |
3 | 3 | " |
4 | 4 | Class { |
5 | 5 | #name : 'CTBSTNode', |
6 | 6 | #superclass : 'CTBSTAbstractNode', |
| 7 | + #instVars : [ |
| 8 | + 'contents', |
| 9 | + 'left', |
| 10 | + 'right' |
| 11 | + ], |
7 | 12 | #category : 'Containers-BinarySearchTree', |
8 | 13 | #package : 'Containers-BinarySearchTree' |
9 | 14 | } |
| 15 | + |
| 16 | +{ #category : 'adding' } |
| 17 | +CTBSTNode >> addChild: anObject [ |
| 18 | + |
| 19 | + anObject < contents |
| 20 | + ifTrue: [ left := left addChild: anObject ] |
| 21 | + ifFalse: [ anObject > contents |
| 22 | + ifTrue: [ right := right addChild: anObject ] ]. |
| 23 | + ^ self |
| 24 | +] |
| 25 | + |
| 26 | +{ #category : 'accessing' } |
| 27 | +CTBSTNode >> contents [ |
| 28 | + |
| 29 | + ^ contents |
| 30 | +] |
| 31 | + |
| 32 | +{ #category : 'accessing' } |
| 33 | +CTBSTNode >> contents: anObject [ |
| 34 | + |
| 35 | + contents := anObject |
| 36 | +] |
| 37 | + |
| 38 | +{ #category : 'accessing' } |
| 39 | +CTBSTNode >> height [ |
| 40 | + |
| 41 | + ^ 1 + (left height max: right height) |
| 42 | +] |
| 43 | + |
| 44 | +{ #category : 'enumerating' } |
| 45 | +CTBSTNode >> inOrderDo: aBlock [ |
| 46 | + |
| 47 | + left inOrderDo: aBlock. |
| 48 | + aBlock value: contents. |
| 49 | + right inOrderDo: aBlock |
| 50 | +] |
| 51 | + |
| 52 | +{ #category : 'initialization' } |
| 53 | +CTBSTNode >> initialize [ |
| 54 | + |
| 55 | + super initialize. |
| 56 | + left := CTBSTNillNode new parent: self. |
| 57 | + right := CTBSTNillNode new parent: self |
| 58 | +] |
| 59 | + |
| 60 | +{ #category : 'testing' } |
| 61 | +CTBSTNode >> isEmpty [ |
| 62 | + |
| 63 | + ^ false |
| 64 | +] |
| 65 | + |
| 66 | +{ #category : 'testing' } |
| 67 | +CTBSTNode >> isLeaf [ |
| 68 | + |
| 69 | + ^ left isEmpty and: [ right isEmpty ] |
| 70 | +] |
| 71 | + |
| 72 | +{ #category : 'accessing' } |
| 73 | +CTBSTNode >> left [ |
| 74 | + |
| 75 | + ^ left |
| 76 | +] |
| 77 | + |
| 78 | +{ #category : 'accessing' } |
| 79 | +CTBSTNode >> left: aNode [ |
| 80 | + |
| 81 | + left := aNode. |
| 82 | + aNode parent: self |
| 83 | +] |
| 84 | + |
| 85 | +{ #category : 'accessing' } |
| 86 | +CTBSTNode >> right [ |
| 87 | + |
| 88 | + ^ right |
| 89 | +] |
| 90 | + |
| 91 | +{ #category : 'accessing' } |
| 92 | +CTBSTNode >> right: aNode [ |
| 93 | + |
| 94 | + right := aNode. |
| 95 | + aNode parent: self |
| 96 | +] |
| 97 | + |
| 98 | +{ #category : 'accessing' } |
| 99 | +CTBSTNode >> search: anObject [ |
| 100 | + |
| 101 | + contents = anObject ifTrue: [ ^ contents ]. |
| 102 | + ^ anObject < contents |
| 103 | + ifTrue: [ left search: anObject ] |
| 104 | + ifFalse: [ right search: anObject ] |
| 105 | +] |
| 106 | + |
| 107 | +{ #category : 'accessing' } |
| 108 | +CTBSTNode >> size [ |
| 109 | + |
| 110 | + ^ 1 + left size + right size |
| 111 | +] |
0 commit comments