GCD of Two Numbers program in Assembly Language
GCD of Two Numbers Algorithm Snapshot
Program code for GCD of Two Numbers
.model small .stack 100 .data no1 dw 0120 no2 dw 0090 gcd dw 0h .code mov ax,@data ; initialize DS mov ds, ax mov ax, no1 ; get the first number mov bx, no2 ; get the second number again: cmp ax, bx ; check if nos are equal je endd ; if equal, save the GCD jb exchg ; if no, ; is AX ; if yes interchange l2: mov dx, 0 div bx ; check if ax is ; divisible by bx cmp dx, 0 ; je endd mov ax, dx ; mov the remainder ; as no1 data jmp again exchg : xchg ax, bx jmp l2 endd : mov gcd, bx mov ch, 04h ; Count of digits to be ; displayed mov cl, 04h ; Count to roll by 4 bits l12: rol bx, cl ; roll bl so that msb ; comes to lsb mov dl, bl ; load dl with data ; to be displayed and dl, 0fH ; get only lsb cmp dl, 09 ; check if digit is 0-9 ; or letter A-F jbe l4 add dl, 07 ; if letter add 37H else ; only add 30H l4: add dl, 30H mov ah, 02 ; INT 21H ; (Display character) int 21H dec ch ; Decrement Count jnz l12 mov ah, 4ch int 21h end
How to Run this Program
For Running this program you should have installed Tasm on you computer . If you have not installed Tasm yet please install from Here .