重做实验七 寻址方式在结构化数据访问中的应用

先处理第一行所有数据:

;实验七  寻址方式在结构化数据访问中的应用

;编程  将data段中的数据 按照如下格式写到table段中,并计算21年中的人均收入(取整)
;结果也按照下面的格式保存在table段中
assume cs:code,ds:data,ss:stack
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个字符串  year

	
    	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个数据
	
	dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
    	dw 11452,14430,15257,17800
	;以上是表示21年公司的员工数量
data ends

table segment
	        ; '0123456789ABCDEF'
	db 21 dup('year sumn ne ?? ')
table ends

stack segment stack
	db	128 dup (0)
stack ends

code segment
start:	mov ax,data
	mov ds,ax
	mov ax,stack
	mov ss,ax
	mov sp,128
	mov ax,table
	mov es,ax

	mov si,0   ;ds:[si]   年份  0~84
	mov di,84  ;ds:[di]   公司总收入  84(54H)~168(A8H)
	mov bx,168 ;ds:[bx]   员工数量   168~210
	mov bp,0   ;es:[bp]   table

	;处理第一行的年份  通过栈	
	push ds:[si] ;拿到低地址  push ds:[si]指将ds:[si]中的内容送入栈中
	pop es:[bp] ;从栈顶取出数据送入es:[bp]
	push ds:[si+2];拿到高地址的那两个字节  ;将ds:[si+2]中的内容送入栈中
	pop es:[bp+2] ;从栈顶取出数据送入es:[bp+2]

	;处理第一行的公司总收入(被除数)  通过寄存器
	        ;  '0123456789ABCDEF'
	;db 21 dup('year sumn ne ?? ')
	mov ax,ds:[di];低位放入ax
	mov dx,ds:[di+2];高位放入dx
	mov es:[bp+5],ax;低位放入5这个位置
	mov es:[bp+7],dx;高位放在7这个位置

	;处理员工数量(除数)
	push ds:[bx]
	pop es:[bp+0AH]
	div word ptr ds:[bx]
	mov es:[bp+0DH],ax;商
	

	mov ax,4c00h
	int 21h




code ends
end start

在这里插入图片描述
在这里插入图片描述
因为总共要处理21行:

;实验七  寻址方式在结构化数据访问中的应用
;编程  将data段中的数据 按照如下格式写到table段中,并计算21年中的人均收入(取整)
;结果也按照下面的格式保存在table段中
assume cs:code,ds:data,ss:stack
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个字符串  year
	
    	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个数据
	
	dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
    	dw 11452,14430,15257,17800
	;以上是表示21年公司的员工数量
data ends

table segment
	        ; '0123456789ABCDEF'
	db 21 dup('year sumn ne ?? ')
table ends

stack segment stack
	db	128 dup (0)
stack ends

code segment
start:	mov ax,data
	mov ds,ax
	mov ax,stack
	mov ss,ax
	mov sp,128
	mov ax,table
	mov es,ax

	mov si,0   ;ds:[si]   年份  0~84
	mov di,84  ;ds:[di]   公司总收入  84(54H)~168(A8H)
	mov bx,168 ;ds:[bx]   员工数量   168~210
	mov bp,0   ;es:[bp]   table

	mov cx,21

	;处理第一行的年份  通过栈	
inputable:
	push ds:[si] ;拿到低地址
	pop es:[bp]
	push ds:[si+2];拿到高地址的那两个字节
	pop es:[bp+2]

	;处理第一行的公司总收入(被除数)  通过寄存器
	        ;  '0123456789ABCDEF'
	;db 21 dup('year sumn ne ?? ')
	mov ax,ds:[di];低位放入ax
	mov dx,ds:[di+2];高位放入dx
	mov es:[bp+5],ax;低位放入5这个位置
	mov es:[bp+7],dx;高位放在7这个位置

	;处理员工数量(除数)
	push ds:[bx]
	pop es:[bp+0AH]
	div word ptr ds:[bx]
	mov es:[bp+0DH],ax;商

	add si,4
	add di,4
	add bx,2
	add bp,16
	loop inputable
	
	mov ax,4c00h
	int 21h

code ends
end start

在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值