|
主题 : : 绝了!比置顶程序还要牛的程序,不另外定义段,只用23条汇编指令完成程序要求。比最牛程序少用了七行代码。 [待解决] |
回复[ 66次 ]
点击[ 6561次 ] | |
|
|
|
|
[帖 主] [ 发表时间: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 希望与热爱技术的人为伍。 | | |
|
|
|
|
[第40楼] [ 回复时间:2011-04-06 10:13 ] | |
荣誉值:0
信誉值:0
注册日期:2011-04-05 23:23 |
现代的程序,代码的可读性远比代码的行数更重要,用代码行数来评价程序的好坏实在是很无聊的事情
楼主的代码还是有些可取之处的,和其他人不同的是他用到了bp,这可以少敲不少字符,我的感觉是,在所有的寻址方式中,只有bx和bp这两个寄存器是最灵活的,应该好好利用,而且在本题后面的提示中也说到,推荐用bx来表示目的地址,所以用bx应该是没问题的,但是是否用bp可能还是有争议,最主要得是因为原题中出题时就直接写es:table了,如果从题目的角度考虑,用bp是有些跑题了,但是从实践的角度来看,用ss和bp应该更好一些,其它的实现大家做得其实都差不多,彼此借鉴一下也好,附上我的本题代码:
assume cs:codesg,ds:data,ss:table
data segment
;年份的21个字符串
db '1975','1976','1977','1978','1979','1980','1981','1982','1983'
db '1984','1985','1986','1987','1988','1989','1990','1991','1992'
db '1993','1994','1995'
;公司总收入的21个双字型数据
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
;公司雇员人数的21个字型数据
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11452,14430,15257,17800
data ends
table segment
db 21 dup ('year summ ne ?? ')
table ends
codesg segment
start:
;初始化数据和表格段地址
mov ax, data
mov ss, ax
mov ax, table
mov ds, ax
; 初始化数据,bp是源地址偏移量,di是dd偏移量(每次+4),si是dw偏移量(每次+2),bx是目的地址偏移量(每次+16)
mov bp, 0
mov bx, 0
mov si, 0
mov di, 0
;初始化循环变量
mov cx, 21
s:
; 填充年份
mov ax, [bp+di]
mov [bx], ax
mov ax, [bp+di+2]
mov [bx+2], ax
; 填充人数
mov ax, [bp+168+si]
mov [bx+10], ax
; 填充收入,这里直接使用了ax,dx是为了div做准备
mov ax, [bp+84+di]
mov [bx+5], ax
mov dx, [bp+84+di+2]
mov [bx+5+2], dx
; 计算平均值
div word ptr [bp+168+si]
mov [bx+13], ax
add di, 4
add si, 2
add bx, 16
loop s
mov ax, 4c00H
int 21H
codesg ends
end start
简单调试结果:
-g 0048
AX=014D BX=0150 CX=0000 DX=2580 SP=0000 BP=0000 SI=002A DI=0054
DS=14DA ES=14BC SS=14CC CS=14EF IP=0048 NV UP EI PL NZ NA PE NC
14EF:0048 B8004C MOV AX,4C00
-d ds:0
14DA:0000 31 39 37 35 20 10 00 00-00 20 03 00 20 05 00 20 1975 .... .. ..
14DA:0010 31 39 37 36 20 16 00 00-00 20 07 00 20 03 00 20 1976 .... .. ..
14DA:0020 31 39 37 37 20 7E 01 00-00 20 09 00 20 2A 00 20 1977 ~... .. *.
14DA:0030 31 39 37 38 20 4C 05 00-00 20 0D 00 20 68 00 20 1978 L... .. h.
14DA:0040 31 39 37 39 20 56 09 00-00 20 1C 00 20 55 00 20 1979 V... .. U.
14DA:0050 31 39 38 30 20 40 1F 00-00 20 26 00 20 D2 00 20 1980 @... &. ..
14DA:0060 31 39 38 31 20 80 3E 00-00 20 82 00 20 7B 00 20 1981 .>.. .. {.
14DA:0070 31 39 38 32 20 A6 5F 00-00 20 DC 00 20 6F 00 20 1982 ._.. .. o. | | |
|