实验内容
Power idea公司从1975年成立一直到1995年的基本情况如下。
年份 收入(千美元) 雇员(人) 人均收入(千美元)
1975 16 3 ?
1976 22 7 ?
1977 382 9 ?
1978 1356 13 ?
1979 2390 28 ?
1980 8000 38 ?
……
1995 5937000 17800 ?
下面的程序中,已经定义好了这些数据:
DATAS SEGMENT
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个字符串
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个word型数据
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,11430,15257,17800
;以上是表示21年公司雇员的21个word型数据
DATAS ENDS
table SEGMENT
db 21 dup('year summ ne ?? ')
table ENDS
编程,将data段中的数据按如下格式写入到table段中,并计算21年的人均收入(取整)
;在内存中按格式存数据
assume cs:code,ds:data,es:table
data segment
db '1975','1976','1977','1978','1979','1980','1981'
db '1982','1983','1984','1985','1986','1987','1988'
db '1989','1990','1991','1992','1993','1994','1995'
dd 16,22,382,1356,2930,8000,16000,24486,50065,97479,140417,197514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793
dw 4037,5635,8226,11542,14430,15252,17800
data ends
table segment
db 21 dup ('year summ ne ?? ')
table ends
code segment
start: mov ax,data
mov ds,ax
mov ax,table
mov es,ax
mov bx,0
mov si,0
mov di,0
mov cx,21
year: mov ax,[di]
mov es:[bx],ax
add di,2
mov ax,[di]
mov es:[bx+2],ax
add di,2
add bx,16
loop year
mov bx,0
mov cx,21
money: mov ax,[di]
mov es:[bx+5],ax
add di,2
mov ax,[di]
mov es:[bx+7],ax
add bx,16
loop money
mov bx,0
mov cx,21
man: mov ax,[di]
mov es:[bx+0ah],ax
add di,2
add bx,16
loop man
mov di,0
mov bx,0
mov cx,21
ave: mov ax,[di+54h]
mov dx,[di+56h]
div word ptr ds:[0a8h+si]
mov es:[0dh+bx],ax
add si,2
add di,4
add bx,16
loop ave
mov ax,4c00h
int 21h
code ends
end start
结果
分析下可知运行结果正确。