标题:王爽 的第八章 最后一个 实验 ('year summ ne ?? ') 是 什么意思 》?哪位 ...
只看楼主
hankbase008
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2010-3-26
结帖率:20%
已结贴  问题点数:9 回复次数:2 
王爽 的第八章 最后一个 实验 ('year summ ne ?? ') 是 什么意思 》?哪位大虾给解释下???
实验七 寻址方式在结构化数据访问中的应用

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    ?

下面的程序中,已经定义好了这些数据:
assume cs:codesg,ds:data
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,1843000,2759000,3753000,4649000,5937000
;以上是表示21年公司总收的21个dword型数据

dw 3,7,9,13,28,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年中的人均收入(取整),结果也按照表8.3所示的格式保存在table段中。



提示:可将data段中的数据看成是多个数组,而将table中的数据看成是一个结构型数据的数组,每个结构型数据中包含多个数据项。可用bx定位每个结构型数据,用idata定位数据项,用si定位数组项中每个元素,对于table中的数据的访问可采用[bx].idata和[bx].idata[si]的寻址方式。
注意:这个程序是到目前为止最复杂的程序,它几乎用到了我们以前学过的所有知识和编程技巧。所以,这个程序是对我们从前学习的最好的实践总结。请认真完成。

答案:

assume cs:codesg,ds:data
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'

dd 16,22,382,1356,2390,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,4037,5635,8226
dw 11542,14430,15257,17800
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 si,0
         mov di,0
         mov bx,0
         mov cx,21
     s: mov al,[bx]
        mov es:[di],al
         mov al,[bx+1]
         mov es:[di+1],al
         mov al,[bx+2]
         mov es:[di+2],al
          mov al,[bx+3]
         mov es:[di+3],al

         mov ax,54h[bx]
         mov dx,56h[bx]
         mov es:5h[di],ax
          mov es:7h[di],dx

          mov ax,0A8h[si]
          mov es:0Ah[di],ax

         mov ax,54h[bx]
          div word ptr ds:0A8h[si]
          mov es:0dh[di],ax

          add bx,4
          add si,2
          add di,16
          loop s
          mov ax,4c00h
          int 21h
codesg ends
end start

文章 中给出的   db 21 dup ('year summ ne ?? ')   

('year summ ne ?? ')   是 什么意思 》?哪位大虾给解释下???

搜索更多相关主题的帖子: year 王爽 summ 实验 
2010-05-12 07:19
ONEPROBLEM
Rank: 6Rank: 6
来 自:广西 南宁
等 级:贵宾
威 望:21
帖 子:1569
专家分:349
注 册:2008-7-11
得分:9 
呵呵,应该没有什么意思啊?
它们只是英文缩写的提示而已吧?
year =>年份
summ =>收入
ne  =>雇员数
?? =>人均收入
在这个数据段中:
table segment
   db 21 dup ('year summ ne ?? ')
table ends
定义了21组的字符串,经编程后,year占4个字节,将被年份代替;summ占4个字节,将被收入数代替;ne占2个字节,将被雇员数代替;??占2个字节,将填入人均收入.
结果例如:
year summ ne ?? =>1975 16 3 5
year summ ne ?? =>1976 22 7 3
... ...类推共21组
2010-05-12 10:09
hankbase008
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2010-3-26
得分:0 
谢谢 貌似明白了点
2010-05-13 06:59



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-306268-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018170 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved