-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathhow to.asm
90 lines (78 loc) · 1.36 KB
/
how to.asm
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
# my quicksort
data segment
a DW 9900H,0890H,0880H,9600H,0860H,0850H,0840H,0830H,0820H,0810H,0800H,0790H,6780H,0770H,0760H,7750H,0740H,0730H,4720H,0710H,0700H,0690H,0680H,0670H,0660H,0650H,0640H,0630H,0620H,0610H,0600H,05B0H,05A0H,0570H,3560H,4550H,0540H,0530H,2520H,0510H,6500H,0490H,3480H,0470H,3460H,0450H,0440H,0430H,0420H,0410H
ends
stack segment stack
ST DB 100 DUP(0)
TOP EQU 300
ends
code segment
assume cs:code, ds:data, ss:stack
start:
mov ax, data
mov ds, ax
mov ax, stack
mov ss, ax
mov sp, TOP
mov si, offset a
mov di, 98
call quicksort
mov ax, 4c00h
int 21h
quicksort proc near
;partition ==> q
cmp si, di
jnb end_quicksort
push si
push di
call partition
pop di
pop si
push di
mov di, bx
sub di, 2
call quicksort
pop di
push si
mov si, bx
add si, 2
call quicksort
pop si
end_quicksort:
RET
quicksort endp
partition proc near
; a, si, di
push ax
push si
push bx
mov bx, si
mov cx, di
sub cx, si
SHR cx, 1
s:
mov ax, [di]
cmp ax, [bx]
ja exchange
add bx, 2
exchange: ;change [bx] with [si]
mov ax, [bx]
push [si]
pop [bx]
mov [si], ax
add si, 2
add bx, 2
loop s
;exchange [si] with [di]
mov ax, [di]
push [si]
pop [di]
mov [si], ax ;now si is the place of the partition place
mov bx, si
pop bx
pop si
pop ax
RET
partition endp
ends
end start