微机原理实验2程序---字符串匹配实验.doc

上传人:sk****8 文档编号:2240052 上传时间:2019-05-02 格式:DOC 页数:5 大小:41.50KB
下载 相关 举报
微机原理实验2程序---字符串匹配实验.doc_第1页
第1页 / 共5页
微机原理实验2程序---字符串匹配实验.doc_第2页
第2页 / 共5页
微机原理实验2程序---字符串匹配实验.doc_第3页
第3页 / 共5页
微机原理实验2程序---字符串匹配实验.doc_第4页
第4页 / 共5页
微机原理实验2程序---字符串匹配实验.doc_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

1、8086 汇编语言源程序 2011 年 湖北汽车工业学院 袁致旺 作8086 汇编语言程序实验:实验二、字符串匹配实验题目:1、 (必做题)编程实现:从键盘分别输入两个字符串(不必等长) ,然后进行比较,若两个字符串有相同的字符,则显示“MATCH” ,若字符都不相同则显示“NO MATCH ”。2、 (选做题)编程实现:从键盘分别输入两个字符串,然后进行比较,若两个字符串的长度和对应字符都完全相同,则显示“MATCH”,否则显示“NO MATCH” 。对应程序如下所示:;第 1 题;=HUICHE MACRO ;定义一个具有回车、换行功能的宏,为程序多次回车换行所调用。MOV DL,0DH

2、;用 2 号功能“显示”回车。MOV AH,02HINT 21HMOV DL,0AH ;用 2 号功能“显示”换行。MOV AH,02HINT 21HENDMDATA SEGMENTMESSAGE1 DB MATCH,$ ;定义“MATCH”提示信息, “$”作为调用 9 号功能的结束符。MESSAGE2 DB NO MATCH,$ ;定义“NO MATCH”提示信息。TISHI1 DB Please input the first string:,$ ;提示输入第 1 个字符串的提示信息。TISHI2 DB Please input the second string:,$ ;提示输入第 1

3、 个字符串的提示信息。STRING1 DB 100 ; 100 为存第一个字符串的最大可用空间的字节数。DB ? ;预留字节,存储将要输入的第 1 个字符串的实际长度。DB 100 DUP(?) ;预留 100 个字节空间,用于存放第 1 个字符串。STRING2 DB 100DB ?DB 100 DUP(?)DATA ENDS8086 汇编语言源程序 2011 年 湖北汽车工业学院 袁致旺 作STACK SEGMENT ;定义一个 50 字节大小的堆栈段空间。ZHAN DB 50 DUP(?)ZHANDING EQU LENGTH ZHANSTACK ENDSCODE SEGMENT ;代码

4、段开始。ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACKSTARTUP: MOV AX,DATA ;程序开始,首先将几个段寄存器初始化为各段的首地址。MOV DS,AX ;MOV ES,AX ;MOV AX,STACK ;MOV SS,AX ;MOV SP,ZHANDING ;栈顶指针赋初值。MOV DX, OFFSET TISHI1 ;用 9 功能显示提示输入第 1 个字符串的提示信息。MOV AH,9INT 21HHUICHE ;调用 宏定义的“回车换行”功能,程序运行到此处时进行回车换行。MOV DX, OFFSET STRING1MOV AH,0AH ;用

5、 10 号功能输入第 1 个字符串。INT 21HHUICHEMOV DX, OFFSET TISHI2MOV AH,9INT 21HHUICHEMOV DX, OFFSET STRING2 ;输入第 2 个字符串。MOV AH,0AHINT 21HHUICHECLD ; 方向标志位清 0,按增址方向操作。MOV SI, OFFSET STRING12 ;将第 1 个字符串第 1 个字符偏移地址传送给 SI,为串搜索做准备。MOV BX,0 ; BX 为后面“记下第 1 个字符串已经被搜索过的字符的个数”做准备。MOV CL, STRING11MOV CH,0 ; 将第 1 个字符串的实际长度

6、赋给 CX。L1: PUSH CX ;先将第 1 个字符串的实际长度压入堆栈,保留,为后面备用。MOV DI, OFFSET STRING22 ;将第 2 个字符串第 1 个字符偏移地址传送给 DI,为串搜索做准备。MOV CL, STRING21 ;将第 2 个字符串的实际长度传送给 CX。MOV CH,0MOV AL,SI8086 汇编语言源程序 2011 年 湖北汽车工业学院 袁致旺 作REPNZ SCASB ;进行串搜索,将第 2 个字符串中的字符与第 1 个字符串的一个字符进行比较。JZ XXX1INC SI ;SI 加 1,指向第 1 个字符串的下一个字符。INC BX ;记下第

7、1 个字符串已经被搜索过的字符的个数。POP CXCMP CX,BX ;“已经被搜索过的字符个数 ”BX 与“第 1 个字符串实际长度”CX 进行比较。JNZ L1 ;若 BX 与 CX 不等,则进行 “第 1 字符串的下一字符”与“第 2 字符串中的字符”的比较。;若 BX 与 CX 相等,则进行执行下面的语句,显示“NO MACTH” 。MOV DX, OFFSET MESSAGE2 ;显示“NO MACTH” 。MOV AH,9INT 21HJMP XXX2 ;显示“NO MACTH”后,跳转到 XXX2,准备返回 DOS 系统。XXX1: MOV DX, OFFSET MESSAGE1

8、 ;显示“MACTH” 。MOV AH,9INT 21HXXX2: MOV AH,1INT 21H ;等待键盘响应,准备返回 DOS 系统。MOV AH,4CH ;返回 DOS 系统,准备结束程序。INT 21HCODE ENDSEND STARTUP ;程序从此处结束。;=8086 汇编语言源程序 2011 年 湖北汽车工业学院 袁致旺 作;第 2 题;=HUICHE MACRO ;定义一个具有回车、换行功能的宏,为程序多次回车换行所调用。MOV DL,0DHMOV AH,02HINT 21HMOV DL,0AHMOV AH,02HINT 21HENDMDATA SEGMENTMESSAGE

9、1 DB MATCH,$MESSAGE2 DB NO MATCH,$TISHI1 DB Please input the first string:,$TISHI2 DB Please input the second string:,$STRING1 DB 100DB ?DB 100 DUP(?)STRING2 DB 100DB ?DB 100 DUP(?)DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATA,ES:DATASTARTUP: MOV AX,DATAMOV DS,AXMOV ES,AXMOV DX, OFFSET TISHI1MOV AH,9I

10、NT 21HHUICHE ;调用 宏定义的“回车换行”功能,程序运行到此处时进行回车换行。MOV DX,OFFSET STRING1MOV AH,0AHINT 21HHUICHEMOV DX, OFFSET TISHI2MOV AH,9INT 21HHUICHEMOV DX,OFFSET STRING2MOV AH,0AH8086 汇编语言源程序 2011 年 湖北汽车工业学院 袁致旺 作INT 21HHUICHECLDMOV SI,OFFSET STRING12 ;将第 1 个字符串第 1 个字符偏移地址传送给 SI,为串比较做准备。MOV BL, STRING11MOV BH,0 ; 将第

11、 1 个字符串的实际长度赋给 BX。MOV DI,OFFSET STRING22 ;将第 2 个字符串第 1 个字符偏移地址传送给 DI,为串比较做准备。MOV CL, STRING21MOV CH,0 ; 将第 2 个字符串的实际长度赋给 CX。CMP BX,CX ;比较两个字符串的长度JNE XXX0 ;若两个字符串的长度不相等,则转到 XXX0 处,显示“NO MACTH” 。REPE CMPSB ;进行串比较,将第 2 个字符串与第 1 个字符串按字符逐一进行比较。JE XXX1 ;若经过比较,两字符串完全相等,则跳到 XXX1 处,显示“MACTH” 。;否则到 XXX0 处,显示“NO MACTH” 。XXX0: MOV DX, OFFSET MESSAGE2 ;显示“NO MACTH” 。MOV AH,9INT 21HJMP XXX2 ;显示“NO MACTH”后,跳转到 XXX2,准备返回 DOS 系统。XXX1: MOV DX, OFFSET MESSAGE1 ;显示“MACTH” 。MOV AH,9INT 21HXXX2: MOV AH,1 ;等待键盘响应,准备返回 DOS 系统。INT 21HMOV AH,4CHINT 21H ;返回 DOS 系统,准备结束程序。CODE ENDSEND STARTUP ;程序从此处结束。;=

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育教学资料库 > 课程笔记

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。