欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    《单片机》编程题题库答案(共51页).doc

    • 资源ID:13479330       资源大小:215.50KB        全文页数:51页
    • 资源格式: DOC        下载积分:20金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要20金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    《单片机》编程题题库答案(共51页).doc

    精选优质文档-倾情为你奉上单片机原理及应用编程题题库参考答案六1、 内部RAM 30H和31H单元中存放着2个0-9的ASCII码(高位字节在前),请将其转换为压缩BCD码(高位在前)并存入外部RAM 2300H单元中。解: ORG 0H LJMP START ORG 30HSTART: MOV A,30H ANL A,#0FH SWAP A MOV R0,A MOV A,31H ANL A,#0FH ORL A,R0 MOV DPTR,#2300H MOVX DPTR,A END评分办法:不要求写出程序的注释。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。2、将存放在内部RAM 30H-35H单元的压缩型BCD码转换成相应的ASCII码,依次存放到外部RAM 2100H开始的单元区中。 ORG 0H LJMP START ORG 30H START:MOV R0,#30H MOV R2,#06H MOV DPTR,#2100H LOOP:MOV A,R0 SWAP A ANL A,#0FH ORL A,#30H MOVX DPTR,A INC DPTR MOV A,R0 ANL A,#0FH ORL A,#30H MOVX DPTR,A INC DPTR INC R0 DJNZ R2,LOOP SJMP $ END评分办法:不要求写出程序的注释。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。3、内部RAM 20H和30H开始的单元分别存放着16个16进制数,请将对应单元的内容相加(不考虑溢出),并将和存入外部RAM 2000H开始的单元中。解: ORG 0 LJMP START ORG 30H START: MOV R0,#20H MOV R1,#30H MOV DPTR,#2000H MOV R2,#08H ;每个单元存放2个16进制数,故16个16进制数占用8个单元 LOOP: MOV A,R0 ADD A,R1 MOVX DPTR,A INC R0 INC R1 INC DPTR DJNZ R2,LOOP SJMP $ END评分办法:不要求写出程序的注释。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。 4、请编写多字节无符号数减法程序。被减数存放在内部RAM 20H开始的8个单元中,减数存放在内部RAM 30H开始的8个单元,请将差存放到外部RAM 2000H开始的8个单元中,借位存放到OV标志中。注意:所有数据均按照从低字节到高字节的顺序存放。 ORG 0 LJMP START ORG 30H START: MOV R0,#20H MOV R1,#30H MOV DPTR,#2000H MOV R2,#08HCLR C LOOP: MOV A,R0 SUBB A,R1 MOVX DPTR,A INC R0 INC R1 INC DPTR DJNZ R2,LOOP MOV OV,C SJMP $ END评分办法:不要求写出程序的注释。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。5、内部RAM 40H和41H单元中存放着2个0-9的ASCII码(高位字节在前),请将其转换为压缩BCD码(高位在前)并存入外部RAM 2000H单元中。解: ORG 0H LJMP START ORG 30HSTART: MOV A,40H ANL A,#0FH SWAP A MOV R0,A MOV A,41H ANL A,#0FH ORL A,R0 MOV DPTR,#2000H MOVX DPTR,A END评分办法:不要求写出程序的注释。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。6、将存放在内部RAM 20H-2FH单元的压缩型BCD码(高位在前)转换成相应的ASCII码,依次存放到外部RAM 1000H开始的单元区中。 ORG 0H LJMP START ORG 30H START: MOV R0,#20H MOV R2,#10H MOV DPTR,#1000H LOOP: MOV A,R0 SWAP A ANL A,#0FH ORL A,#30H (或 ADD A,#30H) MOVX DPTR,A INC DPTR MOV A,R0 ANL A,#0FH ORL A,#30H (或 ADD A,#30H) MOVX DPTR,A INC DPTR INC R0 DJNZ R2,LOOP SJMP $ END评分办法:不要求写出程序的注释。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。7、内部RAM 30H和38H开始的单元分别存放着8个压缩BCD码,请将对应单元的内容相加(不考虑溢出),并将和存入外部RAM 1000H开始的单元中。解: ORG 0 LJMP START ORG 30H START: MOV R0,#30H MOV R1,#38H MOV DPTR,#1000H MOV R2,#08 LOOP: MOV A,R0 ADD A,R1 DA A MOVX DPTR,A INC R0 INC R1 INC DPTR DJNZ R2,LOOP SJMP $ END评分办法:不要求写出程序的注释。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。8、请编写多字节无符号数加法程序。被加数存放在内部RAM 20H开始的8个单元中,加数存放在内部RAM 30H开始的8个单元,请将和存放到外部RAM 2000H开始的8个单元中,进位存放到F0标志中。注意:所有数据均按照从低字节到高字节的顺序存放。 ORG 0 LJMP START ORG 30H START: MOV R0,#20H MOV R1,#30H MOV DPTR,#2000H MOV R2,#08HCLR C LOOP: MOV A,R0 ADDC A,R1 MOVX DPTR,A INC R0 INC R1 INC DPTR DJNZ R2,LOOP MOV F0,C SJMP $ END评分办法:不要求写出程序的注释。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。9、两个8字节压缩BCD码分别存放在内部RAM 30H和40H开始的连续单元中(低位字节在前),请将二者求和(不考虑溢出情况),并将和存入外部RAM 1000H开始的单元中。 解: ORG 0MOV R0,#30H MOV R1,#40H MOV DPTR,#1000H MOV R2,#8 CLR C LOOP: MOV A,R0 ADDC A,R1 DA A MOVX DPTR,A INC R0 INC R1 INC DPTR DJNZ R2,LOOP SJMP $ END10、将存放在内部RAM 20H-2FH单元的十六进制数转换成ASCII码,依次存放到外部RAM 2000H开始的单元中。解: MOV R0,#20H MOV R2,#16 MOV DPTR,#2000H MOV R3, DPH MOV R4, DPL LOOP: MOV A,R0 ANL A,#0FH MOV DPTR,#TAB MOVC A,A+DPTR MOV DPH,R3 MOV DPL,R4 MOVX DPTR,A INC DPTR MOV R3,DPH MOV R4,DPL MOV A,R0 SWAP A ANL A,#0FH MOV DPTR,#TAB MOVC A,A+DPTR MOV DPH,R3 MOV DPL,R4 MOVX DPTR,A INC DPTR MOV R3,DPH MOV R4,DPL INC R0 DJNZ R2,LOOP SJMP $ TAB: DB ABCDEF END11、内部RAM 30H和外部RAM 2200H开始的单元分别存放着两个8字节十六进制数(低位字节存放在前),请将二者相加(不考虑溢出情况),并将和存入内部RAM 40H开始的单元中。解: ORG 0MOV R0,#30H MOV R1,#40H MOV DPTR,#2200H MOV R2,#8 CLR C LOOP: MOVX A,DPTR ADDC A,R0 MOV R1,A INC R0 INC R1 INC DPTR DJNZ R2,LOOP SJMP $ END12、请编写多字节无符号数减法程序。被减数存放在内部RAM 30H开始的8个单元中,减数存放在内部RAM 38H开始的8个单元,请将差存放到外部RAM 1000H开始的8个单元中,借位存放到F0标志中。注意:所有数据均按照从低字节到高字节的顺序存放。解: ORG 0 LJMP START ORG 30HSTART: MOV R0,#30H MOV R1,#38H MOV DPTR,#1000H MOV R2,#8 CLR CLOOP: MOV A,R0 SUBB A,R1 MOVX DPTR,A INC R0 INC R1 INC DPTR DJNZ R2,LOOP MOV C,F0 SJMP $ END13、请编写多字节无符号数减法程序。被减数存放在内部RAM 20H开始的16个单元中,减数存放在内部RAM 30H开始的16个单元,请将差存放到外部RAM 2000H开始的16个单元中,借位存放到OV标志中。注意:所有数据均按照从低字节到高字节的顺序存放。解: ADDR1 EQU 20H ADDR2 EQU 30H LEN EQU 16 ADDR3 EQU 2000H ORG 0 LJMP START ORG 30H START: MOV R0,#ADDR1 MOV R1,#ADDR2 MOV DPTR,#ADDR3 MOV R2,#LEN CLR C LOOP: MOV A,R0 SUBB A,R1 MOVX DPTR,A INC R0 INC R1 INC DPTR DJNZ R2,LOOP MOV OV,C SJMP $ END 14、将存放在内部RAM 20H-3FH单元的压缩BCD码转换成ASCII码,依次存放到外部RAM 2300H开始的单元中。(注:每个单元均先转换高四位)解: LEN EQU 20H ADDR1 EQU 20H ADDR2 EQU 2300H ORG 0 LJMP START ORG 30H START: MOV R0,#ADDR1 MOV DPTR,#ADDR2 MOV R2,#LEN LOOP: MOV A,R0 ANL A,#0F0H SWAP A ORL A,#30H (或 ADD A,#30H) MOVX DPTR,A INC DPTR MOV A,R0 ANL A,#0FH ORL A,#30H (或 ADD A,#30H) MOVX DPTR,A INC DPTR INC R0 DJNZ R2,LOOP SJMP $ END评分办法:程序设计思路正确可得5分,指令完全写对可得10分。不要求使用伪指令。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。 15、将存放在内部RAM 30H-35H单元的十六进制数转换成相应的ASCII码,依次存放到外部RAM 1100H开始的单元区中。(注:每个字节转换时先转换高四位)解: ORG 0 MOV R0,#30H MOV DPTR,#1100H MOV R2,#6LOOP: MOV A,R0 ; 取需要转换的数 ANL A,#0F0H ; 屏蔽低4位 SWAP A PUSH DPH PUSH DPL ; 保护目的地址 MOV DPTR,#TAB MOVC A,A+DPTR ; 查表得ASCII码 POP DPL POP DPH ; 恢复目的地址 MOVX DPTR,A ; 存转换后的ASCII码 INC DPTR ; 修改目的地址指针 MOV A,R0 ; 取需要转换的数 ANL A,#0FH ; 屏蔽高4位 PUSH DPH PUSH DPL ; 保护目的地址 MOV DPTR,#TAB MOVC A,A+DPTR ; 查表得ASCII码 POP DPL POP DPH ; 恢复目的地址 MOVX DPTR,A INC DPTR ; 修改目的地址指针 INC R0 ; 修改源地址指针 DJNZ R2,LOOP ; 未转换完则继续 SJMP $TAB: DB ABCDEF END评分办法:程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。 16、内部RAM 30H开始的单元中存放着16个0-9的ASCII码(高位字节在前),请将其转换为压缩BCD码(高位在前)并存入外部RAM 1000H开始的单元中。解: ORG 0 MOV R0,#30H MOV DPTR,#1000H MOV R2,#8 ; 16个ASCII码转换为8个压缩BCD码LOOP: MOV A,R0 ANL A,#0FH ; 屏蔽高4位得到BCD码 SWAP A MOV R1,A INC R0 ; 指向下一个ASCII码 MOV A,R0 ANL A,#0FH ; 屏蔽高4位得到BCD码 ORL A,R1 ; 合成压缩BCD码 MOVX DPTR,A ; 存压缩BCD码 INC DPTR INC R0 DJNZ R2,LOOP SJMP $ END17、设有两个长度为16字节的数组,分别存放在外部RAM 0200H和0300H为首址的存储区域中,试编写程序求其对应项之和(不考虑溢出的情况),结果存放在以0400H为首址的外部RAM中。解: 参考程序清单如下: ORG 0 MOV R2,#16 ; 数组长度为16个字节 MOV R3,#02H ; 数组1的首地址高8位 MOV R4,#03H ; 数组2的首地址高8位 MOV R5,#04H ; 和数组的首地址高8位 MOV DPL,#0 ; 数据指针低8位清零LOOP: MOV DPH,R3 MOVX A,DPTR ; 取被加数 MOV R1,A ; 存被加数 MOV DPH,R4 MOVX A,DPTR ; 取加数 ADD A,R1 ; 求和 MOV DPH,R5 MOVX DPTR,A ; 存和 INC DPL ; 指向下一字节 DJNZ R2,LOOP ; 未加完则循环 END评分办法:程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。 18、编程求内部RAM中40H4FH共16个单元中的内容的和(结果为2字节),并将和放入50H和51H单元中(高8位在50H)。解: 参考程序清单如下:ORG 0 LJMP START ORG 30H START: MOV R0,#40H ; 数据区首地址送R0 MOV R2,#16 ; 单元数送R2 MOV R3,#0 ; 和的高8位清零CLR A ; 和的低8位清零 LOOP: CLR CADD A,R0 ; 求和 JNC NEXT ; 没有进位则转移 INC R3 ; 和的高8位存储单元内容加1 NEXT: INC R0 ; 指向下一个单元 DJNZ R2,LOOP ; 没加完则循环,和在R3和A中 MOV 51H,A ; 存低8位结果 MOV 50H,R3 ; 存高8位结果 SJMP $ END 19、有一个长度为16字节的ASCII码字符串存放在外部RAM 1000H为首址的存储区域中,字符串中的每一个字符均不相同,试编写程序查找字符串中是否存在ASCII码“9”。如果在字符串中存在ASCII码“9”,则将其存储单元的地址存放到内部RAM 30H和31H单元中(高8位地址在30H单元中),同时将OV标志位清零。否则,将30H和31H单元的内容清零,并将OV标志位置“1”。 解: ORG 0 MOV SP,#60H MOV DPTR,#1000H MOV R2,#16 LOOP: MOVX A,DPTR CJNE A,#39H,EXIT MOV 30H,DPH MOV 31H,DPL CLR OV SJMP $ EXIT: INC DPTR DJNZ R2,LOOP MOV 30H,#0 MOV 31H,#0 SETB OV SJMP $ END 20、有两个8字节的16进制数a和b,它们分别存放在内部RAM中30H37H和40H47H的单元中(高位字节在前)。请编程求a-b,并将差存入30H开始的内部RAM单元中(高位字节在前)。若差小于零则将F0标志位置“1”,否则清零。 解:设计思路:从16进制数的最低位字节(37H和47H)开始相应字节带借位相减,然后修改地址指针在对次低位字节进行相减,一共循环8次完成两个8字节16进制数的相减。最后将Cy标志的内容传送给F0标志位即可。 ORG 0 MOV R0,#37H MOV R1,#47H MOV R2,#8 CLR C LOOP: MOV A,R0 SUBB A,R1 MOV R0,A DEC R0 DEC R1 DJNZ R2,LOOP MOV F0,C SJMP $ END 21、若外部RAM的(3000H)=X,(3001H)=Y,编程实现Z=X*X+2Y,并将结果存到片内RAM的40H单元(设Z256 )。解: X EQU 3000H Y EQU 3001H Z EQU 40H ORG 0 MOV DPTR,#X ; 变量X的地址送DPTR MOVX A,DPTR ; 取变量X MOV B,A ; 变量X的值送给B寄存器 MUL AB ; 求X*X,根据题意知积为1字节(在A中) MOV R0,A ; X*X的结果存入R0中 INC DPTR ; 指向变量Y MOVX A,DPTR ; 取变量Y MOV B,#2 MUL AB ; 求2*Y,根据题意知积为1字节(在A中) ADD A,R0 ; 求X*X+2*Y MOV Z,A ; 和存入40H单元 SJMP $ ; 停机 END评分办法:不要求写出程序的注释和使用伪指令。程序设计思路正确可得5分,指令完全写对可得10分。若仅写对少量指令,可酌情给1-3分;若仅有少量指令写错,可酌情扣1-3分。22、设外部RAM 2000H单元为数据块的起始地址,数据块长度为10,试编程求数据块中的最小值,存入内部RAM 30H单元。解:设计思

    注意事项

    本文(《单片机》编程题题库答案(共51页).doc)为本站会员(飞****2)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开