王爽《汇编语言》(第四版) 实验7

Posted on Oct 19, 2020

这个实验确实是比较繁琐,而且我先是手写的代码,有很多考虑错误的地方,最后花了2个多小时才解决掉。

;迄今为止最麻烦的程序
assume cs:code,es:table,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'

    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

stack segment
    dw 8 dup(0)
stack ends

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

    mov cx,21
    mov bx,0
    mov di,0
    mov si,0
    s:
        push cx
        mov si,0
        mov cx,2
        s1:
            mov ax,[bx][si]
            mov es:[si],ax
            mov ax,54h[bx][si]
            mov es:5[si],ax
            add si,2
        loop s1

        mov ax,ds:0a8h[di]
        mov es:[0ah],ax
        mov ax,[54h+bx]
        mov dx,[56h+bx]
        div word ptr es:[0ah]
        mov es:[0dh],ax

        add di,2
        add bx,4
        ;es++
        mov ax,es
        add ax,1
        mov es,ax

    pop cx
    loop s

    mov ax,4c00h
    int 21h
code ends

end start

这段程序的循环只有两个,而且事实上嵌套的循环也可以写开来,相对而言这个写的还可以,寄存器也十分宽裕,完全没有用到bp,通过栈又可以很容易地不使用di。我个人对这一段非常满意。

最后的部分结果

可以用来对照(我现在还不知道该怎么输出,只好查内存,我太难了)