forked from npocmaka/batch.scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbinaryTree.bat
110 lines (90 loc) · 1.71 KB
/
binaryTree.bat
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
@echo off
setlocal enableDelayedExpansion
:: Binary tree implementation with pure batch
:: only insert and find methods are implmented so far
::
:: it uses the binary tree name as the variable that holds
:: the root element and adds revursively to namer right elements
:: and namel the left elements.
:::--- some tests -----
call ::insert test_tree6 1
call ::insert test_tree6 5
call ::insert test_tree6 8
call ::insert test_tree6 9999
color
echo searching for value 8
call ::find test_tree6 8
echo %errorlevel% - if 0 element is found
echo searching for value 123
call ::find test_tree6 123
echo %errorlevel% - if 1 element is not found
set test_tree6
::::::::::::::::::::::::::::::
exit /b 0
:find three_name value
setlocal enableDelayedExpansion
set /a value=%~2
set node=%1
if %value% equ !%1! (
endlocal & (
echo %1
exit /b 0
)
)
if %value% GTR !%1! (
if defined %1r (
endlocal & (
call ::find %1r %value%
)
) else (
endlocal & exit /b 1
)
)
if %value% LSS !%1! (
if defined %1l (
endlocal & (
call ::find %1l %value%
)
) else (
endlocal & exit /b 1
)
)
exit /b
:insert three_name value
setlocal
::set "three_name=%~1"
set /a value=%~2
if not defined %~1 (
endlocal & (
set "%~1=%value%"
exit /b 0
)
)
if %value% GEQ %~1r (
if not defined %~1r (
endlocal & (
set %~1r=%value%
exit /b 0
)
) else (
endlocal & (
call ::insert %~1r %value%
rem exit /b 0
)
)
)
if %value% LSS %~1l (
if not defined %~1l (
endlocal & (
set %~1l=%value%
exit /b 0
)
) else (
endlocal & (
call ::insert %~1r %value%
rem exit /b 0
)
)
)
exit /b 0
:delete