assume cs:codesg
data 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,184300,2759000,3753000,4649000,5937000
;以上是表示21年公司总收入的21个dword数据
dw 3,7,9,13,20,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430,15257,17800
;以上是表示21年公司雇员人数的21个Word数据
data ends
table segment
db 21 dup('year summ ne ?? ')
table ends
;要求将data中的数据以如下格式写入table段中,并计算21年中的人均收入(取整),结果也按照下面的格式保存在table段中。
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
; 思路: 总体上讲循环21次而中间将有小循环。。思考还要开辟一个栈。。
stack segment
db 32 dup(0)
stack ends
;开辟32个字节的栈空间备用
codesg segment
start:
mov ax,stack
mov ss,ax
mov sp,32 ;初始化栈
mov ax,data
mov ds,ax ;设置数据段
mov ax,table
mov es,ax ;操作段送es
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;第一个loop 把年份复制过去
mov cx,21
mov bx,0
mov bp,0
s0:
push cx
mov si ,0
mov cx,4
s1:
mov al,byte ptr ds:[si][bp]
mov es:[si][bx],al
inc si
loop s1
add bx,16
add bp,4
pop cx
loop s0
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
;第二个loop拷贝
mov bp,84 ;总收入开始相对于ds:0的偏移是84
mov di,0 ;di 做ds的偏移
mov cx,21 ;第二次循环次数。
mov bx,0 ;bx 做es的偏移
s2:
mov byte ptr es:[bx+4],32 ;空格的ASCII码为32
mov byte ptr es:[bx+9],32
mov byte ptr es:[bx+0FH],32
mov byte ptr es:[bx+0FH],32 ;第4,9,C,f 为空格
mov ax,ds:[bp] ;收入低十六位
mov es:[bx+5],ax
mov dx,ds:[bp+2] ;收入高十六位
mov es:[bx+7],dx ;放在dx中,做除法需要
div word ptr ds:[168+di]
mov es:[bx+0DH],ax ;取整送入
mov ax,ds:[168+di]
mov es:[bx+10],ax ;雇员数量
;
add bx,16
add di,2
add bp,4
loop s2
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
mov ax,4c00H
int 21H
codesg ends
end start