整体思路:
每次处理一行的数据,首先把前三个数据转移到结果区,然后计算人均收入直接打印。难点就是对于数据位置计算喜欢出错,弄混几次……
assume cs:codesg
datasg segment
db '1975','1976','1977','1978','1979','1980','1981','1982','1983','1984'
db '1985','1986','1987','1988','1989','1990','1991','1992','1993','1994'
db '1995'
; 0-83
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
; 84-167
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4038,5635,8226
dw 11542,14420,15257,17800
; 168-209
db 0,0,0,0
; 210~213
datasg ends
table segment
;224-
db 21 dup('year summ ne ?? ')
table ends
codesg segment
start:
mov ax,datasg
mov ds,ax ;ds指向原数据寄存器
mov ax,table
mov ss,ax ;ss是指向存结果的寄存器