begin process at 2012 05 24 02:51:15
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

divers

 > EXEMPLE RÉCURSION - FACTORIEL

EXEMPLE RÉCURSION - FACTORIEL


 Information sur la source

 Description

Exemple d'utilisation de récursion en Assembleur

Illustration avec une procedure de factoriel tout simple

le nombre est passé par le stack et le resultat est renvoyé dans le AX si depassement alors AX = 0


Source

  • .model small
  • ; ici les declarations extrn
  • extrn putstrng:far
  • extrn newline:far
  • extrn getdec$:far
  • extrn putdec$:far
  • extrn facto:far
  • ; d'autres extrn s'ils sont necessaires
  • ;
  • .stack 256
  • ;
  • .const
  • ; ici les declaration des constantes, s'il y en a
  • tab db ' '
  • lgtab dw $ - tab
  • .data
  • ; ici les declarations des variables, s'il y en a
  • .code
  • assume ds:dgroup
  • ;
  • debut: mov ax, seg dgroup ; initialisation des regs
  • mov ds, ax
  • mov es, ax
  • ;
  • ; votre programme
  • ;
  • mov bx,0 ;le compteur
  • mov ax,1
  • .while ax != 0
  • push bx
  • call facto
  • push ax
  • .if ax==0
  • jmp terminer
  • .endif
  • mov ax,bx
  • call putdec$
  • lea di,tab
  • mov cx,lgtab
  • call putstrng
  • pop ax
  • call putdec$
  • call newline
  • inc bx
  • terminer:
  • .endw
  • ;FACTO
  • ; terminez avec les instructions suivantes
  • mov ax, 4c00h
  • int 21h
  • FACTO PROC NEAR BASIC, x:word
  • LOCAL y:WORD
  • .if x==0
  • mov ax,1
  • .else
  • push x
  • pop y
  • dec x
  • push x
  • call facto
  • mul y
  • jno fin
  • mov ax,0
  • fin:
  • .endif
  • RET
  • FACTO ENDP
  • end debut
        .model small
; ici les declarations extrn
        extrn   putstrng:far
        extrn   newline:far
        extrn   getdec$:far
        extrn   putdec$:far
	extrn   facto:far

; d'autres extrn s'ils sont necessaires
;
        .stack 256
;
        .const
; ici les declaration des constantes, s'il y en a
tab	db	'        '
lgtab	dw	$ - tab

        .data
; ici les declarations des variables, s'il y en a


        .code
        assume ds:dgroup
;
debut:  mov     ax, seg dgroup     ; initialisation des regs
        mov     ds, ax
        mov     es, ax
;
; votre programme
;
	mov	bx,0			;le compteur
	mov	ax,1		

	.while ax != 0

		push	bx
		call	facto
		push	ax

		.if	ax==0
			jmp	terminer
		.endif

		mov	ax,bx
		call	putdec$
		
		lea	di,tab
		mov	cx,lgtab
		call	putstrng

		pop	ax
		call	putdec$
		call	newline

		inc	bx
terminer:
	.endw
	
;FACTO
; terminez avec les instructions suivantes
        mov     ax, 4c00h
        int     21h

FACTO	PROC	NEAR	BASIC, x:word
	LOCAL	y:WORD

	.if	x==0
		mov	ax,1
	.else
		push	x
		pop	y
		dec	x
		push	x
		call	facto
		mul	y
		jno	fin		
		mov	ax,0
fin:
		
	.endif

	RET

FACTO	ENDP

        end     debut


 Conclusion

Compiler avec MASM 6.15


 Sources de la même categorie

Source avec Zip Source avec une capture MINI DEBUG par parki
Source avec une capture DESSIN DE RECTANGLES (POSITION, TAILLE, COULEUR, ÉPAISSEUR) par macsou01
RECHERCHE DES PALINDROMES D'UN TEXTE SAISI. par PCBill
Source avec Zip LIBRAIRIE GRAPHIQUE (ET PLUS) EN MODE RÉEL par epineurien
Source avec Zip Source avec une capture LIB PROGRESSBAR (PERSONNALISABLE , DÉGRADÉ DE COULEUR,POURCE... par knetus

Commentaires et avis

Aucun commentaire pour le moment.

 Ajouter un commentaire




Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

Photothèque

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,281 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales