微机原理实验报告冒泡法对数据排序.docx
- 文档编号:24752184
- 上传时间:2023-06-01
- 格式:DOCX
- 页数:10
- 大小:248.51KB
微机原理实验报告冒泡法对数据排序.docx
《微机原理实验报告冒泡法对数据排序.docx》由会员分享,可在线阅读,更多相关《微机原理实验报告冒泡法对数据排序.docx(10页珍藏版)》请在冰豆网上搜索。
微机原理实验报告冒泡法对数据排序
实验内容:
用“冒泡“法对一组数300,250,280,240,260,按从小到大的顺序排列。
实验要求:
1.编制程序,对这组数进行排序,并输出原数据及排序后数据;
2.利用DEBU调试工具,用D0命令,查看排序前后,内存数据的变化;
3.去掉最大和最小的两个值,求出其余值的平均值,并输出最大值,最小值和平均值;
4.用学过的压栈PUSHER出栈POP指令,将平均值按位逐个输出(即输出263);
5•将平均值263转化为二进制串,并将这组二进制串输出。
6.所有数据输出前要用字符串的输出指令,进行输出提示(如:
zuidazhi
shi:
300等),所有数据结果能清晰地显示在屏幕上。
程序代码:
DATASEGMEN定义数据段
DT1DW300,250,280,240,260
DT2DB'whatfivedatainputis',0DH,0AH,$
DT3DB'whatafterrankis',0DH,0AH,$
DT4DB'Themaxis',0DH,0AH,$
DT5DB'Theminis',0DH,0AH,$
DT6DB'Theaverageis',0DH,0AH,$
DT7DB'showyoutheaverageonebyone',0DH,0AH,'$'
DT8DB'showyoutheaverageinbinaryform',0DH,0AH,$
DT9DB0DH,0AH,$
DT0DB'B',0DH,0AH,'$'
NEQU5
DATAENDS
CODESEGMENT
ASSUMECS:
CODE,DS:
D;TA明代码段、数据段
STAT:
MOVAX,DATA
MOVDS,AX
LEADX,DT2输出字符串
MOVAH,09H
INT21H
CALLZIXU调用数据输出过程
对数据进行排序:
MOVCX,N-1设置N-1轮比较次数
MOVDX;比较轮次技术
JM4:
PUSHCX
MOVCX,N
SUBCX,DX
LEASI,DT1
JM3:
MOVAX,[SI]
CMPAX,[SI+2]
JLEJM2
XCHGAX,[SI+2]
XCHGAX,[SI]
JM2:
ADDSI,2
LOOPJM3
POPCX
INCDX
LOOPJM4
输出排序后的顺序:
LEADX,DT3
MOVAH,09H
INT21H
CALLZIXU
输出最大值:
LEADX,DT4
MOVAH,09H
INT21H
LEASI,DT1+8;排序后最后一个数就是最大值
MOVAX,[SI]
CALLZIXU1
输出最小值:
LEADX,DT5
MOVAH,09H
INT21H
LEASI,DT1;排序后第一个数就是最小值
MOVAX,[SI]
CALLZIXU1
输出平均值:
LEADX,DT6
MOVAH,09H
INT21H
LEASI,DT1+2;去掉最大最小后的数求和
MOVAX,[SI]
ADDAX,[SI+2]
ADDAX,[SI+4]
MOVBX,3
MOVDX,0
DIVBX求其平均值
MOVCX,AX
CALLZIXU1调用输出程序输出
把平均值分三位输出:
LEADX,DT7
MOVAH,09H
INT21H
MOVAX,CX
MOVBX,100
MOVDX,0
DIVBX
PUSHDX
ADDAL,30H
MOVDL,AL输出平均值的第一位
MOVAH,2
INT21H
LEADX,DT9换行
MOVAH,09H
INT21H
POPDX
MOVAX,DX
MOVBX,10
MOVDX,0
DIVBX
PUSHDX
ADDAL,30H
MOVDL,AL输出平均值的第二位
MOVAH,2
INT21H
LEADX,DT9换行
MOVAH,09H
INT21H
POPDX
ADDDX,30H
MOVAH,2输出平均值的第三位
INT21H
LEADX,DT9
MOVAH,09H
INT21H
;以二进制位输出平均值
LEADX,DT8
MOVAH,09H
INT21H
MOVBX,CX
MOVCX,16
JM5:
MOVDX,0
SALBX,1
RCLDX,1
ADDDX,30H
MOVAH,02H
INT21H
DECCX
JNZJM5
LEADX,DTO
MOVAH,09H
INT21H
MOVAH,4C返回DOS
INT21H
;数据序列的输出写成一个过程:
ZIXUPROC
MOVCX,5
LEASI,DT1
JM1:
MOVAX,[SI]
MOVBX,100
MOVDX,0
DIVBXPUSHDXADDAL,30HMOVDL,ALMOVAH,2INT21HPOPDXMOVAX,DXMOVBX,10MOVDX,0DIVBXPUSHDXADDAL,30HMOVDL,ALMOVAH,2INT21HPOPDXADDDX,30HMOVAH,2
INT21H
LEADX,DT9
MOVAH,09H
INT21H
ADDSI,2
LOOPJM1
RET
ZIXUENDP
;当个数据输出过程:
ZIXU1PRO;将数据的输出写成一个过程
MOVBX,100
MOVDX,0
DIVBX
PUSHDX
ADDAL,30H
MOVDL,AL
MOVAH,2
INT21H
POPDX
MOVAX,DX
MOVBX,10
MOVDX,0
DIVBXPUSHDX
ADDAL,30H
MOVDL,AL
MOVAH,2
INT21H
POPDX
ADDDX,30H
MOVAH,2
INT21H
LEADX,DT9
MOVAH,09H
INT21H
RET
ZIXU1ENDP
CODEENDS
ENDSTAT
调试中出现的一些问题:
1.输入时不慎将字母O当数字0输入,结果导致了下面第5行提示的错误。
2.由于大意将循环标号表错位置,使得出现无限输出的状态。
3.在不该有标点的地方错误的点了标点符号•
4.在写数据输出的程序时,存在逻辑错误,在最高位输出后,本应该将AH清
零,将保存的余数送入AL后继续除,但我第一次恰巧相反,结果出现错
卜面是一些错误的提示:
source
Cross-
SB.ASMC5>:
errorA2009:
Symbolnotdefined:
OAH
SB.ASri<6>:
SB-ASI1<23>:
SB.ASM<42>:
SB.ASM<48>:
SB.ASMC62):
SB.ASM<90>:
经过多次修改和调试,终于能够成功运行,下面是运行结果:
250
280
240
260
whdtdfterrdnl<
240
250
280
300
MdKIS
The
rainis
300
The
240
The
263showvoutheauerogeonebyone
^rogrrinterninatednomal1u
实验总结:
通过实验使得我对这门课有了更深层次的认识,也激发了我对这门课的兴趣,通过编写程序、运行程序,不仅可以巩固以前学过的知识,而且学到了很多在书本山没有的知识。
以前对编程工具及其实验一点也不了解,通过两次的实验课,我已经有了一定的掌握。
我发现,要学好一门语言最好的方法是去用它,只有在使用的过程中,那些苦涩生硬的指令以及语句才会变得鲜活起来,经过多次的使用后,我们不用再去刻意记那些指令的功能,就已经能够很好的掌握和应用了。
在实验过程中,相互讨论也是一大乐趣,大家可以提出自己的想法,然后相互讨论,在进行编程调试,再加上老师的指导,的确是一个相互提高的好方法,可以很快而且高效的提高自己的水平。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微机 原理 实验 报告 冒泡 数据 排序