汇编语言(十六)之三数值求和

输入A、B、C三个数,如果存在一个数为0,则全部清零,否则求和输出

程序运行:

 

代码:


datas segmentA    dw 1B    dw 0D    dw 3S    dw 0a_string      db  0ffh, 0 ,100 dup(?)b_string      db  0ffh, 0 ,100 dup(?)d_string      db  0ffh, 0 ,100 dup(?)	inputA          db 'input A=$'inputB          db 0dh,0ah,'input B=$'inputD          db 0dh,0ah,'input D=$'error_number    db 0dh,0ah,'error number$'outputA         db 0dh,0ah,'A=$'outputB         db 0dh,0ah,'B=$'outputD         db 0dh,0ah,'D=$'outputS         db 0dh,0ah,'S=$'datas endsstacks segment stackdb  100h dup(?)stacks endscodes segmentassume cs:codes,ds:datas,ss:stacks
main   proc  far
start:push dsmov ax,0hpush axmov ax,datas          ;初始化dsmov ds,ax;输入a提示lea dx,inputAmov ah,9int 21h;输入alea dx,a_stringmov ah,10int 21h;a转成十进制数lea si,a_string+1call translate_to_numbermov A,ax;输入b提示lea dx,inputBmov ah,9int 21h;输入blea dx,b_stringmov ah,10int 21h;b转成十进制数lea si,b_string+1call translate_to_numbermov B,ax;输入d提示lea dx,inputDmov ah,9int 21h;输入dlea dx,d_stringmov ah,10int 21h;d转成十进制数lea si,d_string+1call translate_to_numbermov D,axmov ax,Acmp ax,0          ;判断A是否为0jz clear          ;若为0,则清零mov bx,Bcmp bx,0          ;判断B是否为0jz clear          ;若为0,则清零mov dx,Dcmp dx,0          ;判断D是否为0jz clear          ;若为0,则清零add ax,bx         ;求和add ax,dxmov S,ax          ;把求和保存在Sjmp exitclear:mov ax,0           ;清零mov A,axmov B,axmov D,axexit:lea dx,outputA           ;输出A、B、D、Smov ah,9int 21hmov ax,Acall decimallea dx,outputBmov ah,9int 21hmov ax,Bcall decimallea dx,outputDmov ah,9int 21hmov ax,Dcall decimallea dx,outputSmov ah,9int 21hmov ax,Scall decimalretmain endp;字符串转换为十进制数
translate_to_number proc near ;si:lenght firstpush cx push dx push bx push si push di mov di,10mov ax,0mov cl,[si]mov ch,0 cmp cx,0 jz errinc sitran:mov bl,[si]inc sicmp bl,'0'jb errcmp bl,'9'ja err sub bl,30hxor bh,bh	mul di add ax,bx loop tranjmp exiterr:lea dx,error_numbermov ah,9int 21h mov ax,4c00hint 21hexit:pop di pop si pop bx pop dxpop cx ret 
translate_to_number endpdecimal proc nearpush axpush cxpush dxpush bxcmp ax,0jge plusmov bx,axmov dl,'-'mov ah,2int 21hneg bxmov ax,bxplus:mov cx,0mov bx,10de:xor dx,dxdiv bxpush dxinc cxcmp ax,0jnz dede1:pop dxadd dl,30hmov ah,2 int 21h loop de1 pop bxpop dxpop cxpop axret decimal endpcodes endsend main

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/323882.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P4316-绿豆蛙的归宿【数学期望】

正题 评测记录:https://www.luogu.org/recordnew/lists?uid52918&pidP4316 大意 一个有限无环图,绿豆蛙从一个点走向任何一条出边的概率都是一样的,求起点到终点路径的期望长度。 解题思路 有向无环图,我们考虑在拓扑序上…

回忆四班的那些事儿~

10“大家好,我是雄雄,欢迎关注微信公众号:雄雄的小课堂。”今天,谈谈四班的那些事儿吧~对于四班,回忆满满,根本忘却不了。和别的班一样,一个班内总有那么几个调皮捣蛋的孩子,只是四班…

C#使用Xamarin开发可移植移动应用进阶篇(7.使用布局渲染器,修改默认布局),附源码

本篇..基本可以算是Xamarin在应用开发过程中的核心了..真的很很很重要.. 想学习的..想用的..建议仔细阅读..嗯..打酱油的 ..快速滑倒下面点个推荐 - - 哈哈哈... 今天的学习内容? 也只讲一个,关于Xamarin.Forms针对各个平台如何进行可定制化的布局操作. 也就是针对某个平台…

汇编语言(十七)之判断三个数是否相等

输入三个数,计算相等数的个数 程序运行: 代码: datas segmenta db 0ffh, 0 ,100 dup(?)b db 0ffh, 0 ,100 dup(?)d db 0ffh, 0 ,100 dup(?) ARRAY dw 1,2,2inputA db input a$inputB db 0dh,0ah,i…

你想象中的实习是什么样的?

“大家好,我是雄雄,欢迎关注微信公众号:????雄雄的小课堂????。”今天感谢学长小李同学投稿的文章,在校外实习一年,可谓收获满满,下面就是李心焱同学的实习感悟,请欣赏!实习…

P2280-激光炸弹【二维前缀和】

正题 评测链接:https://www.luogu.org/record/show?rid9634929 大意 有nn个东西,在5001∗5001" role="presentation">5001∗50015001∗5001的棋盘上,炸弹一次可以炸r∗rr∗r的地方,使炸到的东西的价值最大。…

汇编语言(十八)之求两个数的最大公约数

输入两个数,使用辗转相除法求最大公约数 程序运行: 代码: datas segmentM_max_len db 0ffhM_len db 0M_string db 100 dup(?)M dw 0 N_max_len db 0ffhN_len db 0N_string db…

Orleans—一些概念

这个文章聊一聊Orleans的概念.以下文章大部分翻译自官方教程,还有一些结合实际的应用经验,并对以前文章留下的坑进行填平.如果有哪个坑没有填,还请告诉我. Grain的生命周期: 一个Grain在逻辑上是永远存在的,并在逻辑上拥有一个不变的标识.程序的代码永远不会去创造或者销毁一个…

使用jdbc连接mysql数据库代码示例

“大家好,我是雄雄,欢迎关注微信公众号:雄雄的小课堂。”最近,正好在看jdbc,于是就整理了一份增删改查的案例,记录记录,以备后用!!java编辑器:myeclipse![10]…

POJ1958-Strange Towers of Hanoi【递推】

正题 题目链接:http://poj.org/problem?id1958 大意 有4根柱子的汉诺塔,有n个盘,求移动次数 解题思路 首先我们定义只有三根柱子时有n个盘的话移动次数是dndn,然后dndn−1∗21dndn−1∗21定义有四根柱子时有n个盘移动次数为fn…

[上海站] 微软Azure AspNetCore微服务实战

活动介绍 2017官方发布了EshopOnContainers的微服务项目,其结合了.Net Core、Azure、Docker等众多优秀的技术,为开发者们抛砖引玉,走进微服务的大门。 本次分享,我们将结合实际毫无保留的从代码上解析微服务架构,以实…

一个朋友的一天,太酸了!

“大家好,我是雄雄,欢迎关注微信公众号:雄雄的小课堂。”6:00,起床,洗漱。6:45,戴上耳机,打开XX读书,边听边骑车,去上班,由于是新车跑新路,想怎么…

汇编语言(十九)之删除数组中的元素

在数组中删除所有-1元素,然后输出删除后的长度 程序运行: 代码: datas segmentLink dw 15 ,1,2,3,4,5,6,-9,-1,3,4,5,3,-1,-2,3ouput db Link length:$ datas endsstacks segment stackdb 100h dup(?)stacks endscodes segmentassume cs…

vijos1197-费解的开关【递推,枚举,位运算】

正题 题目链接:https://vijos.org/p/1197 大意 有5*5个开关,每次选择一个地方时它和它上下左右的开关都会取反,求将所有开关都变成1的最少次数。 解题思路 首先我们知道一个位置一定不会点击超过一次。这样我们就可以得出一条性质&#xf…

Linux+.NetCore+Nginx搭建集群

本篇和大家分享的是LinuxNetCoreNginx搭建负载集群,对于netcore2.0发布后,我一直在看官网的文档并学习,关注有哪些新增的东西,我,一个从1.0到2.0的跟随者这里只总结一句话:2.0版本,api更多&…

老师 累了,我们 泪了!

“以下文章来自一位不愿意透露姓名的同学所写:”呀呼 “老穆头” 没错是我们的穆老师悄悄往我们班探了探头瞧了瞧我们, 我们依旧对他那么热情,紧随其后老佟往门口一站 教室里立马严肃起来 她是我们级部出了名没人敢惹的老佟(佟老…

汇编语言(二十)之分类统计字符个数

输入一串字符串,分别统计英文字符,数字字符和其他字符的个数 程序运行: 代码: datas segmentline_max_length db 0ffhline db 0, 100h dup(?)letter_count dw 0digit_count dw 0other_count …

POJ3263-Tallest Cow【前缀和】

正题 大意 有n头牛,两头牛可以相互看见仅当他们中间没有比他们高的牛,现在已经知道最高的牛是第p头,高度为h。还知道m对关系表示两头牛之间可以相互看见,求每头牛最高高度。 解题思路 我们先无视最高的一头牛,我们假…

.NET Core+Selenium+Github+Travis CI =amp;gt; SiteHistory

前言 总是三分钟热度的我折腾了一个可以每天自动截取指定网站页面并保存到Github的项目SiteHistory,感觉挺好(每次都这样 frameborder"0" scrolling"no" style"border-width: initial; border-style: none; width: 25px; height: 26px;&qu…

汇编语言(二十一)之数值交换与自增

输入两个数,如果第一个数为偶数第二个数为奇数,互换位置;如果两个数都是奇数,则两个数都加一 程序运行: 代码: datas segmentA dw 0 B dw 0a_string db 0ffh, 0 ,100h dup(?)b_string …