Accueil > > > RECURSIVITE EN ASM
RECURSIVITE EN ASM
Information sur la source
Description
ce programme illustre la recursivite en assembleur on utilise comme example la fonction de "FIBONACCI" et la "FACTORIEL"
Source
- DONNE SEGMENT
-
- MESSAGE DB 10,13,"*********CE PROGRAMME CALCULE LE SUIT DE FIBONACCI EN ASSEMBLEUR*******",10,13,'$'
- UN_NUMERO DB 10,13," ENTRER LE RANG : ",'$'
- RESULTAT DB 10,13," VIOCI LE RESULTAT ",'$'
- MSGFACTO DB 10,13," ET POUR LE FACTORIELLE LE RESULTATA EST : ",'$'
- MSGERREUR DB 10,13,"ENTRER UN NOMBRE SVP",'$'
- DONNE ENDS
-
- CODE SEGMENT
-
- ASSUME CS:CODE,DS:DONNE
- debut:
- MOV AX,DONNE
- MOV DS,AX
-
- LEA DX,MESSAGE
- MOV AH,09H
- INT 21H
- LEA DX,UN_NUMERO
- INT 21H
- MOV BX,0
- MOV CX,10
- ;LECTURE ET CONVERTION DES DU NOMBRE LU DANS LE REGISTRE BX
- LECT:
- MOV AH,01H ;on lit un caractaire
- INT 21H
- CBW
- CMP AL,13 ; si c'est ENTRER on va la suit du programme
- JE SUIT
- CMP AL,30H ;SINON ON VERIFIE SI C'EST UN CHIFFRE
- JL ERREUR
- CMP AL,39H
- JA ERREUR
- SUB AL,30H ;si oui on lui soustrait 30H
- XCHG AX,BX
- MUL CX ;on multiplie le resultat deja obtenu par 10
- JC SUIT
- ADD AX,BX ;ON L'ADDITIONNE AVEC LE NOMBRE LU
- XCHG AX,BX ; on met le resultat dans bx
- JMP LECT
- SUIT:
- MOV CX,BX ;ON MET DANS CX LE RAG
- PUSH CX
- CALL FIBO
- MOV DX,OFFSET RESULTAT
- MOV AH,09H
- INT 21H
- CALL AFFICHE
- POP CX
- CALL FACTO
- MOV BX,AX
- LEA DX,MSGFACTO
- MOV AH,09H
- INT 21H
- CALL AFFICHE
- JMP FIN
- ERREUR:
- LEA DX,MSGERREUR
- MOV AH,09H
- INT 21H
- FIN:
- MOV AH,01H
- INT 21H
- MOV AH,4CH
- INT 21H
- ;*************************************************
- ; LA PROCEDURE NON RECURSIVE DE FIBONACCI
- ;*************************************************
- FIBO:
- XOR AX,AX
- JCXZ RETOURE
- MOV BX,AX
- INC AX
- CMP CX,1
- JBE RETOURE
- TANQUE:
- PUSH AX
- ADD AX,BX
- POP BX
- LOOP TANQUE
- RETOURE:
- RET
- ;***************************************************
- ; LA PROCEDURE D'AFFICHAGE DU RESULTAT
- ;***************************************************
- AFFICHE:
- mov cl,10
- MOV AX,BX
- MOV SI,0
- MOV DX,0
- convert:
- INC SI
- div CX
- cmp AX,0
- je BOUCLE
- ADD DL,30H
- PUSH DX
- CWD
- JMP CONVERT
- BOUCLE:
- ADD DX,30H
- PUSH DX
- BCL:
- POP DX
- MOV AH,02H
- INT 21H
- DEC SI
- CMP SI,0
- JNE BCL
- ret
- ;*******************************************************************
- ;******************************************************************
- ;**** LA FONCTION FACTORIELLE RECURSIF ****
- ;******************************************************************
- FACTO:
- XOR AX,AX
- INC AX
- FACTORIELLE:
- JCXZ RET_PROG
- MUL CX
- DEC CX
- CALL FACTORIELLE ;ICI LE CALL EST SEULLEMENT FAIR ILLUSION A LA RECURSIVITE
- ; LE RESULTAT RESTERA LE MEME AVEC UN JMP MAIS TRES EFFICASSE
- RET_PROG:
- ret
-
- ;**** FIN DE LA PROCEDURE ******
- CODE ENDS
- END debut
DONNE SEGMENT
MESSAGE DB 10,13,"*********CE PROGRAMME CALCULE LE SUIT DE FIBONACCI EN ASSEMBLEUR*******",10,13,'$'
UN_NUMERO DB 10,13," ENTRER LE RANG : ",'$'
RESULTAT DB 10,13," VIOCI LE RESULTAT ",'$'
MSGFACTO DB 10,13," ET POUR LE FACTORIELLE LE RESULTATA EST : ",'$'
MSGERREUR DB 10,13,"ENTRER UN NOMBRE SVP",'$'
DONNE ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DONNE
debut:
MOV AX,DONNE
MOV DS,AX
LEA DX,MESSAGE
MOV AH,09H
INT 21H
LEA DX,UN_NUMERO
INT 21H
MOV BX,0
MOV CX,10
;LECTURE ET CONVERTION DES DU NOMBRE LU DANS LE REGISTRE BX
LECT:
MOV AH,01H ;on lit un caractaire
INT 21H
CBW
CMP AL,13 ; si c'est ENTRER on va la suit du programme
JE SUIT
CMP AL,30H ;SINON ON VERIFIE SI C'EST UN CHIFFRE
JL ERREUR
CMP AL,39H
JA ERREUR
SUB AL,30H ;si oui on lui soustrait 30H
XCHG AX,BX
MUL CX ;on multiplie le resultat deja obtenu par 10
JC SUIT
ADD AX,BX ;ON L'ADDITIONNE AVEC LE NOMBRE LU
XCHG AX,BX ; on met le resultat dans bx
JMP LECT
SUIT:
MOV CX,BX ;ON MET DANS CX LE RAG
PUSH CX
CALL FIBO
MOV DX,OFFSET RESULTAT
MOV AH,09H
INT 21H
CALL AFFICHE
POP CX
CALL FACTO
MOV BX,AX
LEA DX,MSGFACTO
MOV AH,09H
INT 21H
CALL AFFICHE
JMP FIN
ERREUR:
LEA DX,MSGERREUR
MOV AH,09H
INT 21H
FIN:
MOV AH,01H
INT 21H
MOV AH,4CH
INT 21H
;*************************************************
; LA PROCEDURE NON RECURSIVE DE FIBONACCI
;*************************************************
FIBO:
XOR AX,AX
JCXZ RETOURE
MOV BX,AX
INC AX
CMP CX,1
JBE RETOURE
TANQUE:
PUSH AX
ADD AX,BX
POP BX
LOOP TANQUE
RETOURE:
RET
;***************************************************
; LA PROCEDURE D'AFFICHAGE DU RESULTAT
;***************************************************
AFFICHE:
mov cl,10
MOV AX,BX
MOV SI,0
MOV DX,0
convert:
INC SI
div CX
cmp AX,0
je BOUCLE
ADD DL,30H
PUSH DX
CWD
JMP CONVERT
BOUCLE:
ADD DX,30H
PUSH DX
BCL:
POP DX
MOV AH,02H
INT 21H
DEC SI
CMP SI,0
JNE BCL
ret
;*******************************************************************
;******************************************************************
;**** LA FONCTION FACTORIELLE RECURSIF ****
;******************************************************************
FACTO:
XOR AX,AX
INC AX
FACTORIELLE:
JCXZ RET_PROG
MUL CX
DEC CX
CALL FACTORIELLE ;ICI LE CALL EST SEULLEMENT FAIR ILLUSION A LA RECURSIVITE
; LE RESULTAT RESTERA LE MEME AVEC UN JMP MAIS TRES EFFICASSE
RET_PROG:
ret
;**** FIN DE LA PROCEDURE ******
CODE ENDS
END debut
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Assembleur ... [ par pi0up51 ]
Voilà je voulais savoir qch ..Je fais un bac S spécialité Science de l'ingenieur et on fais de la programmation assembleur, sur un vieux microcontrole
Deux Questions (Pas compliqué) [ par Dalamar ]
Je commence en Assembleur et j'ai deux questions:1-Je travaille avec dev-c++ et je voudrais savoir comment on inclus de l'assembleur2-J'ai trouvé u
Quel assembleur choisir ? [ par trinitacs ]
J'aimerai savoir quel est le meilleur assembleur qui existe ou si il en faut mixer. Je début difficielment l'asm avec NASM. Faut-il choisir MASM, TASM
langage c /assembleur [ par almai467 ]
salut ..!mon projet de fin d'annee est un logiciel (compteur internet) qui compte la duree de la connexion internet et le cout avec le langage c je c'
Programmation assembleur d'un pilote de souris serie [ par Scaq ]
COUCOU, C SCAQ...J'ai du mal à recevoir les données de ma souris serie
compilateur assembleur [ par morganitos ]
Salut a tous ce qui liront ce message.Je débute en programmation assembleur et voici ma question : où pourrai-je trouver un assembleur, un linker ...(
Petit problème pour le nul en assembleur que je suis Merci d'avance [ par rgc50 ]
Trouver parmis les 5 nombres 67, 79, 15, e3, 72 le nombre le pls élevé, on le stockera le résultat en 0100 (en assembleur 68000 (MOTOROLA)).
Pb assembleur très facile (pas pour moi) Merci d'avance [ par rgc50 ]
Trouver parmis les 5 nombres 67, 79, 15, e3, 72 le nombre le pls élevé, on le stockera le résultat en 0100 (en assembleur 68000 (MOTOROLA)).
Commander un PCF 8574 en assembleur 68000 [ par Apophis74 ]
Je cherche quelqu'un qui pourrait m'adier à faire communiquer ma carte Coldfire 5307 avec une carte d'ES PCF8574 via le bus I2C en assembleur 68000. M
Utilistaionde l'I2C en assembleur 68000 [ par Apophis74 ]
Je cherche une source qui pourrait m'aider à utiliser le bus I2C de ma carte Coldfire 5307 en asssembleur 68000. Help me!Apophis74
|
Derniers Blogs
MYTIC - SHAREPOINT 2010 : DéJà UN MYTHE MICROSOFT ?MYTIC - SHAREPOINT 2010 : DéJà UN MYTHE MICROSOFT ? par junarnoalg
La prochaine session de MyTIC aura lieu à Namur, le 23 mars prochain. Pendant presque une heure, nous parlerons de SharePoint 2010. Voici un aperçu du programme.
Accueil : 17h30 Début de la session : 18h00 - Les nouvelles int...
Cliquez pour lire la suite de l'article par junarnoalg [MIX10] KEYNOTE DEUXIèME JOURNéE - INTERNET EXPLORER 9, HTML5, VISUAL STUDIO 2010, ODATA[MIX10] KEYNOTE DEUXIèME JOURNéE - INTERNET EXPLORER 9, HTML5, VISUAL STUDIO 2010, ODATA par cyril
Le deuxième keynote du mix fut très riche en contenu. Internet Explorer 9 Juste un après le lancement de Internet Explorer 8, Microsoft a dévoilé les nouveautés de Internet Explorer 9. Désormais, IE supportera HTML5, SVG et CSS3. L'élément ...
Cliquez pour lire la suite de l'article par cyril CERTIFICATIONS BETA .NET 4CERTIFICATIONS BETA .NET 4 par KooKiz
Les inscriptions pour les certifications beta .NET 4 ont commencé. L'inscription est offerte pour les examens suivants : - 71-511, TS: Windows Applications Development with Microsoft .NET Framework 4 - 71-515, TS: Web Applications Development with...
Cliquez pour lire la suite de l'article par KooKiz [MIX 2010] - MICROSOFT TRANSLATOR TECHNOLOGY PREVIEW V2[MIX 2010] - MICROSOFT TRANSLATOR TECHNOLOGY PREVIEW V2 par redo
J'imagine que la plupart d'entre vous connaissent bien et utilisent le service de traduction de Google, mais connaissez-vous celui de Microsoft . Microsoft Translator ? Effectivement, Microsoft nous annoncé le lancement version 2 de la Technologie Preview...
Cliquez pour lire la suite de l'article par redo
Forum
RE : ASSEMBLEURRE : ASSEMBLEUR par ghuysmans99
Cliquez pour lire la suite par ghuysmans99 RE : ASSEMBLEURRE : ASSEMBLEUR par ghuysmans99
Cliquez pour lire la suite par ghuysmans99 ASSEMBLEURASSEMBLEUR par solleil
Cliquez pour lire la suite par solleil
Logiciels
Academy System (10.9.4.0)ACADEMY SYSTEM (10.9.4.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods
|