. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->数据处理的两个基本问题
主题 : :  绝了!比置顶程序还要牛的程序,不另外定义段,只用23条汇编指令完成程序要求。比最牛程序少用了七行代码。  [待解决] 回复[ 66次 ]   点击[ 6561次 ]  
netson
[帖 主] [ 发表时间:2009-07-02 10:50 ] 
荣誉值:0
信誉值:0
注册日期:2008-09-26 07:46
code segment 
start:mov ax,data 
      mov ds,ax 
      mov bx,0 
      mov si,0a8h 
      mov ax,table 
      mov ss,ax 
      mov bp,0 
      mov cx,21 
    s:mov ax,[si] 
      mov [bp+0ah],ax 
      mov ax,[bx] 
      mov dx,{bx+2} 
      mov [bp],ax 
      mov [bp+2],dx 
      mov ax,[54h+bx] 
      mov dx,[56h+bx] 
      mov [bp+05h],ax 
      mov [bp+07h],dx 
      div word ptr [bp+0ah] 
      mov [bp+0dh],ax 
      add bx,4 
      add si,2 
      add bp,10h 
      loop s 
      mov ax,4c00h
      int 21h
code ends 
end start 
我的QQ:479488993       我的博客:http://www.asmedu.net/blog/user/usermain.jsp?neighborId=14266  希望与热爱技术的人为伍。
zjkl19
[第45楼] [ 回复时间:2013-12-21 17:43 ] 
荣誉值:0
信誉值:6
注册日期:2009-07-15 11:17
16楼的程序对这道题来说,确实很好。
不过我个人觉得,这样的代码结构性和可读性都很差,比如说从结构化设计程序的角度来说,按顺序,最好先处理“收入”数据,再处理“雇员数”数据,不然要处理的数据类型如果很多的话,打乱顺序以后程序的结构就显得混乱。
另外,SI寄存器是(Source Index)的缩写,DI寄存器是(Destination Index)的缩写,SI一般是用来访问“源数据”的,DI一般是用来访问“目标数据”的,16楼的程序把SI和DI都用来访问“源数据”,显得混乱,如果程序稍微复杂那么一点点,比如说再定义1个段,以3个字节存储公司每年的排名,这种方法就不行了。从结构化的角度来说,不如多用几个循环,使程序变得清晰。
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved