HTT_音乐 发表于 2014-6-10 14:38:33

实验六

本帖最后由 HTT_音乐 于 2014-6-10 14:58 编辑

(第1、2、3、4题小甲鱼老师讲了就不再重做了)
(5)、程序如下,编写 code 段中的代码,将 啊段和 b 段中的数据依次相加,将结果存到 c 段中。assume cs:code

a segment
      db 1, 2, 3, 4, 5, 6, 7, 8
a ends

b segment
      db 1, 2, 3, 4, 5, 6, 7, 8
b ends

d segment
      db 0, 0, 0, 0, 0, 0, 0, 0
d ends

code segment
start:      mov ax, d
      mov ss, ax

      mov ax, a
      mov ds, ax
      mov ax, b
      mov es, ax

      mov bx, 0
      mov cx, 8
s:      mov al,
      add al, es:
      mov ss:, al
      inc bx
      loop s

      mov ax, 4c00H
      int 21H
code ends
end start

HTT_音乐 发表于 2014-6-10 14:58:12

(6)、程序如下,编写 code 段中的代码,用 push 指令将 a 段中的前 8 个字型数据,逆序存储到 b 段中。assume cs:code

a segment
        dw 1, 2, 3, 4, 5, 6, 7, 8, 9, 0aH, 0bH, 0cH, 0dH, 0eH, 0fH, 0ffH
a ends

b segment
        dw 0, 0, 0, 0, 0, 0
b ends

code segment
start:        mov ax, b
        mov ss, ax
        mov sp, 16

        mov ax, a
        mov ds, ax

        mov bx, 0
        mov cx, 8
s:        mov ax,
        push ax
        add bx, 2
        loop s

        mov ax, 4c00H
        int 21
code ends
end start

code ends
end start(思路:把 b 段设置为栈,而栈本身的排序规则就是逆序排序。所以直接 push a 段前面的 8 个字型数据就可以了)

zuosy 发表于 2016-11-29 18:16:25

哎呦,不错呦。[赞][赞][赞]
页: [1]
查看完整版本: 实验六