寻址方式在结构化数据访问中的应用解决方案

寻址方式在结构化数据访问中的应用
看王爽的《汇编语言》课后有一实验——“实验7 寻址方式在结构化数据访问中的应用”,硬是写不出来,在网上找了很多,有的结果出来的,也正确,可是代码风格上总感觉别扭,不是我想要的,也就是没找到自己觉得满意的答案。最后还是自己码出来了,结果正确,代码风格合适,母不嫌子丑,自我感觉挺好的,嘿嘿,毕竟花了不少时间码出来的。我贴出来是想得到更好的理解和更多的进步,希望理解。如果还有值得改进的地方,请师傅们斧正。

;实验7 寻址方式在结构化数据访问中的应用
;编程,将data段中的数据按如下格式写入到table段中,并计算21年中的人均收入(取整),结果也按照下面的格式保存在table段中。

assume cs:codesg, ds:data
data segment
;ds:0
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年的21个字符串
;ds:54h
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
;以上是表示21年公司总收的21个dword型数据
;ds:0a8h
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430,45257,17800
;以上是表示21年公司雇员人数的21个word型数据
data ends
table segment
db 21 dup('year summ ne ?? ');
table ends
codesg segment
start:
mov ax,data
mov ds,ax
mov ax,table
mov es,ax

mov cx,21
mov bx,0
mov si,0
mov di,0
s:

mov ax,0[si][0]
mov es:[bx].0[0], ax ;year
mov ax,0[si][2]
mov es:[bx].0[2], ax ;year
mov ax,54h[si][0]
mov es:[bx].5[0], ax ;summ
mov ax,54h[si][2]
mov es:[bx].5[2], ax ;summ
mov ax,0a8h[di][0]
mov es:[bx].0ah[0], ax ;ne

mov ax,es:[bx].5[0] ;被除数的低位 2 byte
mov dx,es:[bx].5[2] ;被除数的高位 2 byte
div word ptr es:[bx].0ah[0];summ/ne取整数
mov es:[bx].0dh[0],ax ;??商,余数在dx中

add bx,10h
add si,4
add di,2
loop s

mov ax,4c00h
int 21h
codesg ends
end start


------解决方案--------------------
mov ax,a[di][0] 

a db '1975','1976','1977','1978','1979','1980','1981','1982','1983' 


------解决方案--------------------
引用:
怎么没人来跟贴呀,哪怕是捡几分的人也没得寻址方式在结构化数据访问中的应用解决方案

你这样能汇编通过吗?