-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathBubbleSort_02.asm
More file actions
98 lines (73 loc) · 1.3 KB
/
BubbleSort_02.asm
File metadata and controls
98 lines (73 loc) · 1.3 KB
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
.MODEL SMALL
.STACK 100H
.DATA
ARR DB 100 DUP(?)
N DW ?
MSG1 DB 'Enter the amount or numbers : $'
MSG2 DB 'Enter the numbers : $'
MSG3 DB 'After Bubble sort : $'
.CODE
MAIN PROC
include 'emu8086.inc'
MOV AX,@DATA
MOV DS,AX
LEA DX,MSG1
MOV AH,9
INT 21H
MOV AH,1
INT 21H
SUB AX,130H
MOV N,AX
;printn ''
MOV AH,2
MOV DL,0AH
INT 21H
MOV DL,0DH
INT 21H
MOV CX,N
MOV SI,OFFSET ARR
LEA DX,MSG2
MOV AH,9
INT 21H
input:
MOV AH,1
INT 21H
MOV [SI],AL
INC SI
print ' '
LOOP input
printn ''
;sort
MOV CX,N
DEC CX
loop1:
MOV BX,CX
MOV SI,0
comparing:
MOV AL,ARR[SI]
MOV DL,ARR[SI+1]
CMP AL,DL
JC noswap
MOV ARR[SI],DL
MOV ARR[SI+1],AL
noswap:
INC SI
DEC BX
JNZ comparing
loop loop1
LEA DX,MSG3
MOV AH,9
INT 21H
MOV CX,N
MOV SI,OFFSET ARR
output:
MOV AH,2
MOV DL,[SI]
INT 21H
INC SI
print ' '
LOOP output
MOV AH,4CH
INT 21H
MAIN ENDP
END MAIN