- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
微机原理实验2程序---字符串匹配实验
8086汇编语言源程序 2011年 湖北汽车工业学院 袁致旺 作
8086汇编语言程序实验:
实验二、字符串匹配实验
题目:
(必做题)编程实现:从键盘分别输入两个字符串(不必等长),然后进行比较,若两个字符串有相同的字符,则显示“MATCH”,若字符都不相同则显示“NO MATCH”。
(选做题)编程实现:从键盘分别输入两个字符串,然后进行比较,若两个字符串的长度和对应字符都完全相同,则显示“MATCH”,否则显示“NO MATCH”。
对应程序如下所示:
;第1题
;====================================
HUICHE MACRO ;定义一个具有回车、换行功能的宏,为程序多次回车换行所调用。
MOV DL,0DH ;用2号功能“显示”回车。
MOV AH,02H
INT 21H
MOV DL,0AH ;用2号功能“显示”换行。
MOV AH,02H
INT 21H
ENDM
DATA SEGMENT
MESSAGE1 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个字符串的提示信息。
STRING1 DB 100 ; 100为存第一个字符串的最大可用空间的字节数。
DB ? ;预留字节,存储将要输入的第1个字符串的实际长度。
DB 100 DUP(?) ;预留100个字节空间,用于存放第1个字符串。
STRING2 DB 100
DB ?
DB 100 DUP(?)
DATA ENDS
STACK SEGMENT ;定义一个50字节大小的堆栈段空间。
ZHAN DB 50 DUP(?)
ZHANDING EQU LENGTH ZHAN
STACK ENDS
CODE SEGMENT ;代码段开始。
ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK
STARTUP: 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,9
INT 21H
HUICHE ;调用 宏定义的“回车换行”功能,程序运行到此处时进行回车换行。
MOV DX, OFFSET STRING1
MOV AH,0AH ;用10号功能输入第1个字符串。
INT 21H
HUICHE
MOV DX, OFFSET TISHI2
MOV AH,9
INT 21H
HUICHE
MOV DX, OFFSET STRING2 ;输入第2个字符串。
MOV AH,0AH
INT 21H
HUICHE
CLD ; 方向标志位清0,按增址方向操作。
MOV SI, OFFSET STRING1[2] ;将第1个字符串第1个字符偏移地址传送给SI,为串搜索做准备。
MOV BX,0 ; BX为后面“记下第1个字符串已经被搜索过的字符的个数”做准备。
MOV CL, STRING1[1]
MOV CH,0 ; 将第1个字符串的实际长度赋给CX。
L1: PUSH CX ;先将第1个字符串的实际长度压入堆栈,保留,为后面备用。
MOV DI, OFFSET STRING2[2] ;将第2个字符串第1个字符偏移地址传送给DI,为串搜索做准备。
MOV CL, STRING2[1] ;将第2个字符串的实际长度传送给CX。
MOV CH,0
MOV AL,[SI]
REPNZ SCASB ;进行串搜索,将第2个字符串中的字符与第1个字符串的一个字符进行比较。
JZ XXX1
INC SI ;SI加1,指向第1个字符串的下一个字符。
INC BX ;记下第1个字符串已经
原创力文档


文档评论(0)