- 1、本文档共41页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
例:有数组 x(x1,x2,……,x10) 和 y(y1,y2,……,y10),
编程计算 z(z1,z2,……,z10)
z1 = x1 + y1
z2 = x2 + y2
z3 = x3 - y3
z4 = x4 - y4
z5 = x5 - y5
z6 = x6 + y6
z7 = x7 - y7
z8 = x8 - y8
z9 = x9 + y9
z10= x10 + y10 ; x dw x1,x2,x3,x4,x5,x6,x7,x8,x9,x10
y dw y1,y2,y3,y4,y5,y6,y7,y8,y9,y10
z dw z1,z2,z3,z4,z5,z6,z7,z8,z9,z10
logic_rule dw 00dch ;0000,0000,1101,1100
……
mov bx, 0
mov cx, 10
mov dx, logic_rule
next: mov ax, x[bx]
shr dx, 1
jc subtract
add ax, y[bx]
jmp short result ; 向前引用
subtract:
sub ax, y[bx]
result: mov z[bx], ax
add bx, 2
loop next
……;;查表法,实现一位16进制数转换为ASCII码显示
data segment
ASCII db 30h,31h,32h,33h,34h,35h
db 36h,37h,38h,39h ;0~9的ASCII码
db 41h,42h,43h,44h,45h,46h;A~F的ASCII码
hex db 0bh ;任意设定一个待转换的一位16进制数
data ends
code segment
main proc far
assume cs:code,ds:data
start:
push ds
xor ax,ax
push ax
mov ax,data
mov ds,ax
;-------------
mov bx,offset ASCII ;BX指向ASCII码表
mov al,hex ;AL取得一位16进制数,正是ASCII码表中位移 ;例:将正数 n 插入一个已整序的正数字数组。该数组的
首地址和末地址分别为ARRAY_HEAD, ARRAY_END。;●由于数组已经排好序,因此可以将正数n依次和数组中的数进行比较,比较有个方向问题,这里假设数组在存储单元中按地址递增的方向从小到大依次存放。不妨从大数开始进行比较,当遇到第一个比n小的数,记下该位置,该位置就是要插入n 的位置。
●找到出入位置后,如何在不破坏原来数据顺序基础上插入n呢?打个比方:9个同学按高矮依次做在1~10号椅子上,现在第10个同学按照高矮要做在第5号椅子上,那么如何空出第5号椅子呢,但仍然保持高矮次序?只要9号同学移到10号, 9 ?10, 8 ?9, 7 ?8, 6 ?7, 5 ?6就可以了。同样,我们可以如法炮制,数组中将要插入数n位置前的数依次前移一个位置(两个字节),空出要插入位置,将n放入即可。
●在插入数时,可能遇到特殊情况,即数n比数组中所有的数都要大,或者小。若比所有的数都大,就??需要移动原数组中的数,直接插入即可;若比所有的数都小,就将数n放在数组的首位置。; 很显然,查找位置和空出位置的过程就是循环比较的过程,因此采用循环结构来实现,那么,循环条件如何确定呢?其中一种比较容易想到循环条件就是:数组长度(或数组首地址)及K=n,其中K为依次从数组中取出的一个数。
另外,可以充分利用题目中的已知条件即数组中的数均为正数,所以我们可以在数组的开始的前一个位置存放一个负数,不妨存放数-1,这样,在循环控制时就不需要用数组长度来进行控制,可以进一步简化程序的设计。而且需要注意的是,有可能一次都不需要移动数组中的数。因此,应选择DO—WHILE 结构形式。; 合肥学院 计算机科学与技术系 何立新 《汇编语言程序设计》;x dw
您可能关注的文档
- 法院起源与的发展2.ppt
- 我国石油大学(北京)院系专业技术.doc
- 国产手机vs苹果手机.docx
- 城乡的发展差距由来课件.ppt
- 反恐行动红色利剑图文全攻略全关卡解析攻略.pdf
- 医用传感器第一讲绪论.ppt
- 烘焙入门必看草莓奶酪慕斯蛋糕.pdf
- 烘焙店筹建工作总结及管理建议.doc
- 2012福建质检文综地理.ppt
- 六年级语文养成读报好习惯.ppt
- 2024年广东省公务员考试行测试卷历年真题附答案详解(完整版).docx
- 《建筑防水工程质量控制要点在建筑防生物侵蚀中的应用研究》教学研究课题报告.docx
- 2025至2030全球及中国物流中的物联网(IoT)行业市场深度研究及发展前景投资可行性分析报告.docx
- 2025至2030全球及中国物流可视化系统行业市场深度研究及发展前景投资可行性分析报告.docx
- 2024年广东省公务员考试行测试卷历年真题及答案详解(考点梳理).docx
- 2024年广东省公务员考试行测试卷历年真题及答案详解(有一套).docx
- 工业互联网视角下离散制造业供应链协同优化:协同模式创新与协同效率教学研究课题报告.docx
- 2024年广东省公务员考试行测试卷历年真题及答案详解(易错题).docx
- 2024年广东省公务员考试行测试卷历年真题及答案详解(名师系列).docx
- 2025至2030全球及中国物理吸附分析行业市场深度研究及发展前景投资可行性分析报告.docx
文档评论(0)