- 1、本文档共47页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
单片机应用技术(高职高专)
ORG 0100H BLOCK1 DATA 20H BLOCK2 DATA 30H MOV R0,#BLOCK1 MOV R1,#BLOCK2 ;设置两个地址指针 MOV R2,#10 ;设置循环计数器初值 CLR C ;进位标志初值为0 LOOP: MOV A,@R0 ;取被加数到A ADDC A,@R1 ;加数与被加数相加并加低位进位,结果放A中 MOV @R0,A ;存结果 INC R0 ;指针指向被加数更高位 INC R1 ;指针指向加数更高位 DJNZ R2,LOOP ;未加完则继续 CLR A ADDC A,#0 ;加最高位的进位 MOV @R0,A ;保存最高位的进位 SJMP $ END 3.4.3 查找、排序程序 1.查表程序 查表操作可用DPTR的值或PC的值作基地址。 用DPTR的值作基地址的查表步骤为: (1)把表的首地址送到DPTR; (2)把所查表的项数(即在表格中的地址是第几项)送入累加器A中; (3)执行查表指令:MOVC A,@A+DPTR查表的结果送入A中。 用PC的值作基地址的查表步骤为: (1)将查表的项数送入累加器A中; (2)将MOVC A,@A+PC指令的下一条指令到表格首地址的指令字节数与累加器A的值相加; (3)执行查表指令:MOVC A,@A+PC,查表的结果送入A中。 【例3.9】 用查表法求Y=X2。设X的值在R0中,X的取值范围为0—9,结果送R0中。 解:用PC的值作基地址进行查表求解。程序如下: ORG 0100H MOV A,R0 ;1字节 ADD A,#03 ;2字节 MOVC A,@A+PC ;1字节 MOV R0,A ;1字节 SJMP $ ;2字节 TABLE: DB 0,1,4,9,16 DB 25,36,49,64,81 END 2.查找程序 数据极值查找是指在给定的数据区中选出最大值或最小值。从一批数据中寻找最大值或最小值的方法很多,最常用的方法是采用比较交换法。 【例3.10】 数据极值查找程序。内部RAM 30H单元开始存放了10个数,找出其中最大的数。 解:题意分析:我们采用比较交换法来查找最大数。先指定一MAX单元,使第一个数存入MAX单元,然后把它和数据块中每一个数逐一比较,大的数存放在MAX单元,直到数据块中每个数都比较完,此时MAX单元中得到最大数。 程序流程如图所示。源程序如下: 数据极值查找程序流程图 ORG 0100H MAX DATA 50H MOV R0,#30H ;数据首址送R0 MOV R2,#10 ;数据长度送R2 MOV MAX,@R0 ;读第一个数 DEC R2 LOOP1:INC R0 MOV A,@R0 ;读下一个数 CJNE A,MAX,CHK ;数值比较 CHK:JC LOOP2 ;MAX大转移 MOV MAX,A ;大数送MAX LOOP2:DJNZ R2, LOOP1 ;继续循环 SJMP $ ;停止 END 3. 数据排序程序 数据排序是将数据块中的数据按升序或降序排列。数据排序方法很多,常用的方法有冒泡法或沉降法。 【例3.11】 片内RAM中数据块排序程序。内部RAM有一无符号数据块,工作寄存器R0指向数据块的首地址,其长度存放在R2中,请将数据块中的数据按从大到小顺序进行排列,排列后数据仍存放在原来位置。 解:题意分析:数据排列程序常采用冒泡法。一次冒泡即找到数据块极小值放到数据块最后,再一次冒泡次小数排在倒数第二位置,多次冒泡实现降序排列。 程序流程图如图所示。源程序如下: N Y 交换标志位清0 顺序取一个数 指针加1 顺序取下一数并比较 两数交换 交换标志置位 前一个数大 比较一遍 有交换标志 开 始 结 束 Y Y N N 数据极值查找程序流程图 SORT: MOV A,R0 MOV
文档评论(0)