文档库 最新最全的文档下载
当前位置:文档库 › 清华大学版汇编语言答案

清华大学版汇编语言答案

清华大学版汇编语言答案
清华大学版汇编语言答案

附录:《IBM—PC汇编语言程序设计》习题参考答案

第一章.习题

1.1用降幂法和除法将下列十进制数转换为二进制数和十六进制数:

(1) 369 (2) 10000 (3) 4095 (4) 32767

答:(1) 369=1 0111 0001B=171H

(2) 10000=10 0111 0001 0000B=2710H

(3) 4095=1111 1111 1111B=FFFH

(4) 32767=111 1111 1111 1111B=7FFFH

1.2将下列二进制数转换为十六进制数和十进制数:

(1) 10 1101 (2) 1000 0000 (3) 1111 1111 1111 1111 (4) 1111 1111

答:(1) 10 1101B=2DH=45

(2) 1000 0000B=80H=128

(3) 1111 1111 1111 1111B=FFFFH=65535

(4) 1111 1111B=FFH=255

1.3将下列十六进制数转换为二进制数和十进制数:

(1) FA (2) 5B (3) FFFE (4) 1234

答:(1) FAH=1111 1010B=250

(2) 5BH=101 1011B=91

(3) FFFEH=1111 1111 1111 1110B=65534

(4) 1234H=1 0010 0011 0100B=4660

1.4完成下列十六进制数的运算,并转换为十进制数进行校核:

(1) 3A+B7 (2) 1234+AF (3) ABCD-FE (4) 7AB×6F

答:(1) 3A+B7H=F1H=241

(2) 1234+AFH=12E3H=4835

(3) ABCD-FEH=AACFH=43727

(4) 7AB×6FH=35325H=217893

1.5下列各数均为十进制数,请用8位二进制补码计算下列各题,并用十六进制数表示其运算结果。

(1) (-85)+76 (2) 85+(-76) (3) 85-76 (4) 85-(-76) (5) (-85)-76 (6) -85-(-76)

答:(1) (-85)+76=1010 1011B+0100 1100B=1111 0111B=0F7H;CF=0;OF=0

(2) 85+(-76)=0101 0101B+1011 0100B=0000 1001B=09H;CF=1;OF=0

(3) 85-76=0101 0101B-0100 1100B=0101 0101B+1011 0100B=0000 1001B=09H;CF=0;OF=0

(4) 85-(-76)=0101 0101B-1011 0100B=0101 0101B+0100 1100B=10100001B=0A1H;CF=0;OF=1

(5) (-85)-76=1010 1011B-0100 1100B=1010 1011B+1011 0100B=0101 1111B=5FH;CF=0;OF=1

(6) -85-(-76)=1010 1011B-1011 0100B=1010 1011B+0100 1100B=11110111B=0F7H;CF=0;OF=0 1.6下列各数为十六进制表示的8位二进制数,请说明当它们分别被看作是用补码表示的带符号数或

无符号数时,它们所表示的十进制数是什么?

(1) D8 (2) FF

答:(1) D8H表示的带符号数为-40,D8H表示的无符号数为216;

(2) FFH表示的带符号数为-1,FFH表示的无符号数为255。

1.7下列各数均为用十六进制表示的8位二进制数,请说明当它们分别被看作是用补码表示的数或字

符的ASCII码时,它们所表示的十进制数及字符是什么?

(1) 4F (2) 2B (3) 73 (4) 59

答:(1) 4FH表示的十进制数为79,4FH表示的字符为O;

(2) 2BH表示的十进制数为43,2BH表示的字符为+;

(3) 73H表示的十进制数为115,73H表示的字符为s;

(4) 59H表示的十进制数为89,59H表示的字符为Y。

1.8请写出下列字符串的ASCII码值。

For example,

This is a number 3692.

答:46H 6FH 72H 20H 65H 78H 61H 6DH 70H 6CH 65H 2CH 0AH 0DH 54H 68H 69H 73H 20H 69H 73H 20H 61H 20H 6EH 75H 6DH 62H 65H 72H 20H 33H 36H 39H 32H 2EH 0AH 0DH

第 二 章. 习 题

2.1 在80x86微机的输入/输出指令中,I/O 端口号通常是由DX 寄存器提供的,但有时也可以在指令

中直接指定00~FFH 的端口号。试问可直接由指令指定的I/O 端口数。 答:可直接由指令指定的I/O 端口数为256个。 2.2 有两个16位字1EE5H 和2A3CH 分别存放在80x86微机的存储器的

000B0H 和000B3H 单元中,请用图表示出它们在存储器里的存放情况。 答:存储器里的存放情况如右上图所示。

2.3 在IBM PC 机的存储器中存放信息如右下图所示。试读出30022H 和

30024H 字节单元的内容,以及30021H 和30022H 字单元的内容。

答:30022H 字节单元的内容为ABH ;30024H 字节单元的内容为EFH 。

30021H 字单元的内容为AB34H ;30022H 字单元的内容为CDABH 。 2.4 在实模式下,段地址和偏移地址为3017:000A 的存储单元的物理地址是

什么?如果段地址和偏移地址是3015:002A 和3010:007A 呢? 答:3017:000A 、3015:002A 和3010:007A 的存储单元的物理地址都是3017AH 。 2.5 如果在一个程序开始执行以前(CS)=0A7F0H ,(如16进制数的最高位为

字母,则应在其前加一个0) (IP)=2B40H ,试问该程序的第一个字的物理

地址是多少?

答:该程序的第一个字的物理地址是0AAA40H 。 2.6 在实模式下,存储器中每一段最多可有10000H 个字节。如果用调试程

序DEBUG 的r 命令在终端上显示出当前各寄存器的内容如下,请画出此时存储器分段的示意图,以及条件标志OF 、SF 、ZF 、CF 的值。

C>debug -r

AX=0000 BX=0000 CX=0079 DX=0000 SP=FFEE BP=0000 SI=0000 DI=0000 DS=10E4 ES=10F4 SS=21F0 CS=31FF IP=0100 NV UP DI PL NZ NA PO NC 答:此时存储器分段的示意图如右图所示。OF 、SF 、ZF 、CF 的值都为0。 2.7 下列操作可使用那些寄存器?

(1) 加法和减法 数据寄存器等

(2) 循环计数 CX (3) 乘法和除法 AX 、DX ,乘数和除数用其他寄存器或存储器

(4) 保存段地址 段寄存器 (5) 表示运算结果为0 ZF=1 (6) 将要执行的指令地址 CS:IP (7) 将要从堆栈取出数据的地址 SS:SP 答:答案见题目的右边。 2.8 那些寄存器可以用来指示存储器地址?

答:BX 、BP 、SI 、DI 、堆栈操作时的SP 、对应的段地址、386及其后继机型的Exx 。 2.9 请将下列左边的项和右边的解释联系起来(把所选字母放在括号中):

(1) CPU (M) A.保存当前栈顶地址的寄存器。 (2) 存储器 (C) B.指示下一条要执行的指令的地址。 (3) 堆栈 (D) C.存储程序、数据等信息的记忆装置,微机有RAM 和ROM 两种。 (4) IP (B) D.以后进先出方式工作的存储空间。 (5) SP (A) E.把汇编语言程序翻译成机器语言程序的系统程序。 (6) 状态标志 (L) F.唯一代表存储空间中每个字节单元的地址。 (7) 控制标志 (K) G.能被计算机直接识别的语言。

34H

30021H ABH

30022H CDH 30023H EFH 30024H 存储器

2.3题的信息存放情况 12H 30020H E5H 000B0H 1EH 000B1H 3CH 000B3H 2AH

000B4H

存储器 2.2题的信息存放情况

… 000B2H

10F40 10E40

20F40

20E40 21F00 31F00

31FF0 41FF0

附加段 数据段 堆栈段

代码段 2.6 题的存储器分段示意图

(8) 段寄存器(J) H.用指令的助记符、符号地址、标号等符号书写程序的语言。

(9) 物理地址(F) I.把若干个模块连接起来成为可执行文件的系统程序。

(10) 汇编语言(H) J.保存各逻辑段的起始地址的寄存器,8086/8088机有四个:CS、DS、

SS、ES。

(11) 机器语言(G) K.控制操作的标志,如DF位。

(12) 汇编程序(E) L.记录指令操作结果的标志,共6位:OF、SF、ZF、AF、PF、CF。

(13) 连接程序(I) M.分析、控制并执行指令的部件,由算术逻辑部件ALU和寄存器等

组成。

(14) 指令(O) N.由汇编程序在汇编过程中执行的指令。

(15) 伪指令(N) O.告诉CPU要执行的操作(一般还要指出操作数地址),在程序运行时

执行。

答:答案见题目的括号中。

第三章.习题

3.1给定(BX)=637DH,(SI)=2A9BH,位移量D=7237H,试确定在以下各种寻址方式下的有效地址是

什么?

(1) 立即寻址

(2) 直接寻址

(3) 使用BX的寄存器寻址

(4) 使用BX的简接寻址

(5) 使用BX的寄存器相对寻址

(6) 基址变址寻址

(7) 相对基址变址寻址

答:(1) 操作数在指令中,即立即数;

(2) EA=D=7237H;

(3) 无EA,操作数为(BX)=637DH;

(4) EA=(BX)=637DH;

(5) EA=(BX)+D=0D5B4H;

(6) EA=(BX)+(SI)=8E18H;

(7) EA=(BX)+(SI)+D=1004FH;超过了段的边界,最高进位位丢失,因此EA=004FH。

3.2试根据以下要求写出相应的汇编语言指令

(1) 把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器中。

(2) 用寄存器BX和SI的基址变址寻址方式把存储器中的一个字节与AL寄存器的内容相加,并

把结果送到AL寄存器中。

(3) 用寄存器BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字和(CX)相加,并把结

果送回存储器中。

(4) 用位移量为0524H的直接寻址方式把存储器中的一个字与数2A59H相加,并把结果送回存储

单元中。

(5) 把数0B5H与(AL)相加,并把结果送回AL中。

答:(1) ADD DX, BX

(2) ADD AL, [BX][SI]

(3) ADD [BX+0B2H], CX

(4) ADD WORD PTR [0524H], 2A59H

(5) ADD AL, 0B5H

3.3写出把首地址为BLOCK的字数组的第6个字送到DX寄存器的指令。要求使用以下几种寻址方

式:

(1) 寄存器间接寻址

(2) 寄存器相对寻址

(3) 基址变址寻址

答:(1) MOV BX, OFFSET BLOCK

ADD BX, (6–1)*2

MOV DX, [BX]

(2) MOV BX, OFFSET BLOCK 改为: MOV BX, (6-1)*2 MOV DX, [BX+(6–1)*2] 也可 MOV DX, BLOCK[BX]

(3) MOV BX, OFFSET BLOCK MOV SI, (6–1)*2 MOV DX, [BX][SI]

3.4 现有(DS)=2000H ,(BX)=0100H ,(SI)=0002H ,(20100H)=12H ,(20101H)=34H ,(20102H)=56H ,

(20103H)=78H ,(21200H)=2AH ,(21201H)=4CH ,(21202H)=B7H ,(21203H)=65H ,试说明下列各条指令执行完后AX 寄存器的内容。 (1) MOV AX, 1200H (2) MOV AX, BX (3) MOV AX, [1200H] (4) MOV AX, [BX] (5) MOV AX, 1100[BX] (6) MOV AX, [BX][SI] (7) MOV AX, 1100[BX][SI] 答:(1) (AX)=1200H (2) (AX)=0100H (3) (AX)=4C2AH (4) (AX)=3412H

(5) (AX)=4C2AH (6) (AX)=7856H (7) (AX)=65B7H 3.5 给定(IP)=2BC0H ,(CS)=0200H ,位移量D=5119H ,(BX)=1200H ,(DS)=212AH ,(224A0H)=0600H ,

(275B9H)=098AH ,试为以下的转移指令找出转移的偏移地址。 (1) 段内直接寻址

(2) 使用BX 及寄存器间接寻址方式的段内间接寻址 (3) 使用BX 及寄存器相对寻址方式的段内间接寻址

答:(1) JMP NEAR PTR 5119H ;(IP)=5119H+((IP)+03H)=7CDCH ,物理地址PA=09CDCH

(IP)+03H 是JMP NEAR PTR 5119H 指令的下一条指令的首地址。

(2) JMP WORD PTR [BX] ;(IP)=((DS)*10H+(BX))=0600H ,PA=02600H (3) JMP D[BX] ;(IP)=((DS)*10H+(BX)+D)=098AH ,PA=0298AH 3.6 设当前数据段寄存器的内容为1B00H ,在数据段的偏移地址2000H 单元内,含有一个内容为0FF10H 和8000H 的指针,它们是一个16位变量的偏移地址和段地址,试写出把该变量装入AX 的指令序列,并画图表示出来。 答:MOV BX, [2000H] ;图示如上所示。

MOV AX, [2000H+2]

MOV ES, AX

MOV AX, ES:[BX] 3.7 在0624H 单元内有一条二字节JMP SHORT OBJ 指令,如其中位移量为(1) 27H ,(2) 6BH ,(3)

0C6H ,试问转向地址OBJ 的值是多少? 答:(1) OBJ=0624H+02H+27H=064DH

(2) OBJ=0624H+02H+6BH=0691H (3) OBJ=0624H+02H+0C6H=05ECH ;C6H 对应的负数为-3AH (向上转移,负位移量) 3.8 假定(DS)=2000H ,(ES)=2100H ,(SS)=1500H ,(SI)=00A0H ,(BX)=0100H ,(BP)=0010H ,数据段中变量名V AL 的偏移地址为0050H ,试指出下列源操作数字段的寻址方式是什么?其物理地址值是多少?

(1) MOV AX, 0ABH (2) MOV AX, BX (3) MOV AX, [100H] (4) MOV AX, VAL (5) MOV AX, [BX] (6) MOV AX, ES:[BX] (7) MOV AX, [BP] (8) MOV AX, [SI] (9) MOV AX, [BX+10] (10) MOV AX, VAL[BX] (11) MOV AX, [BX][SI] (12) MOV AX, VAL[BX][SI] 答:(1) 立即方式; 操作数在本条指令中

FFH 00H 80H 3.6题的作图表示

10H 1B00:2000H 1B00:2001H 1B00:2002H 1B00:2003H

8000:FF10H 8000:FF11H ?→(AL)

?→(AH) MOV BX, 2000H LES BX, [BX] MOV AX, ES :[BX]

(2) 寄存器寻址方式; 操作数为 (BX)=0100H (3) 直接寻址方式; PA=20100H (4) 直接寻址方式; PA=20050H (5) BX 寄存器间接寻址方式; PA=20100H (6) 附加段BX 寄存器间接寻址方式; PA=21100H (7) BP 寄存器间接寻址方式; PA=15010H (8) SI 寄存器间接寻址方式; PA=200A0H (9) BX 寄存器相对寻址方式; PA=20110H (10) BX 寄存器相对寻址方式; PA=20150H (11) BX 和SI 寄存器基址变址寻址方式; PA=201A0H (12) BX 和SI 寄存器相对基址变址寻址方式; PA=201F0H

3.9 在ARRAY 数组中依次存储了七个字数据,紧接着是名为ZERO 的字单元,表示如下:

ARRAY DW 23, 36, 2, 100, 32000, 54, 0 ZERO DW ?

(1) 如果BX 包含数组ARRAY 的初始地址,请编写指令将数据0传送给ZERO 单元。 (2) 如果BX 包含数据0在数组中的位移量,请编写指令将数据0传送给ZERO 单元。 答:(1) MOV AX, [BX+(7-1)*2]

MOV [BX+(7)*2], AX (2) MOV AX, ARRAY [BX] MOV ARRAY [BX+2], AX 3.10 如TABLE 为数据段中0032单元的符号名,其中存放的内容为1234H ,试问以下两条指令有什么

区别?指令执行完后AX 寄存器的内容是什么? MOV AX, TABLE LEA AX, TABLE 答:MOV AX, TABLE 是将TABLE 单元的内容送到AX ,(AX)=1234H

LEA AX,TABLE 是将TABLE 单元的有效地址送到AX ,(AX)=0032H

3.11 执行下列指令后AX 寄存器中的内容是什么? TABLE DW 10, 20, 30, 40, 50 ;000AH, 0014H, 001EH, 0028H, 0032H ENTRY

DW 3 ┇ MOV BX, OFFSET TABLE

ADD BX, ENTRY

MOV AX, [BX]

答:(AX)=1E00H (TABLE 的存储方式如右图所示) 3.12 下列ASCII 码串(包括空格符)依次存储在起始地址为CSTRING 的字节单元中:

CSTRING DB ?BASED ADDRESSING ‘

请编写指令将字符串中的第1个和第7个字符传送给DX 寄存器。 答:MOV DH, CSTRING

MOV DL, CSTRING+7-1

3.13 已知堆栈段寄存器SS 的内容是0FFA0H ,堆栈指针寄存器SP 的内容是00B0H ,先执行两条把8057H

和0F79H 分别进栈的PUSH 指令,再执行一条POP 指令。试画出堆栈区和SP 的内容变化过程示意图(标出存储单元的物理地址)。

答:堆栈区和SP 的内容变化过程示意图如下左图所示。

3.14 设(DS)=1B00H ,(ES)=2B00H ,有关存储单元的内容如上右图所示。请写出两条指令把字变量X

0AH 00H 14H 00H

1EH

00H

28H 00H

32H 00H

TABLE TABLE+3 3.11题的TABLE 存储方式 3.13 (SP)←(SP)-2 (SP)←(SP)-2 出栈时(SP)←(SP)+2 8000H 1B00:2000 3.14题的存储区情况 2B00H

X 1B00:2002 2B00:8000

装入AX寄存器。

答:MOV BX, [2000H]

MOV AX, ES:[BX]

3.15求出以下各十六进制数与十六进制数62A0H之和,并根据结果设置标志位SF、ZF、CF和OF的

值。

(1) 1234H (2) 4321H (3) CFA0H (4) 9D60H

答:(1) 和为74D4H;SF=0,ZF=0,CF=0,OF=0

(2) 和为A5C1H;SF=1,ZF=0,CF=0,OF=1

(3) 和为3240H;SF=0,ZF=0,CF=1,OF=0

(4) 和为0000H;SF=0,ZF=1,CF=1,OF=0

3.16求出以下各十六进制数与十六进制数4AE0H的差值,并根据结果设置标志位SF、ZF、CF和OF

的值。

(1) 1234H (2) 5D90H (3) 9090H (4) EA04H

答:(1) 差为C754H;SF=1,ZF=0,CF=1,OF=0

(2) 差为12B0H;SF=0,ZF=0,CF=0,OF=0

(3) 差为45B0H;SF=0,ZF=0,CF=0,OF=1

(4) 差为9F24H;SF=1,ZF=0,CF=0,OF=0

3.17写出执行以下计算的指令序列,其中X、Y、Z、R、W均为存放16位带符号数单元的地址。

(1) Z←W+(Z-X) (2) Z←W-(X+6)-(R+9)

(3) Z←(W*X)/(Y+6),R←余数(4) Z←((W-X)/5*Y)*2

答:(1) MOV AX, Z ;以下程序都未考虑带符号数的溢出

SUB AX, X

ADD AX, W

MOV Z, AX

(2) MOV BX, X

ADD BX, 6

MOV CX, R

ADD CR, 9

MOV AX, W

SUB AX, BX

SUB AX, CX

MOV Z, AX

(3) ADD Y, 6

MOV AX, W

IMUL X

IDIV Y

MOV Z, AX

MOV R, DX

(4) MOV AX, W

SUB AX, X

CWD

MOV BX, 5

IDIV BX

IMUL Y

SHL AX, 1 ;((DX),(AX))*2

RCL DX, 1

3.18已知程序段如下:

MOV AX, 1234H ;(AX)=1234H,标志位不变

MOV CL, 4 ;(AX)和标志位都不变

ROL AX, CL ;(AX)=2341H,CF=1,SF和ZF不变

DEC AX ;(AX)=2340H,CF=1不变,SF=0,ZF=0

MOV CX, 4 ;(AX)和标志位都不变

MUL CX ;(AX)=8D00H,CF=OF=0,其它标志无定义

INT 20H

试问:

(1) 每条指令执行完后,AX寄存器的内容是什么?

(2) 每条指令执行完后,进位、符号和零标志的值是什么?

(3) 程序结束时,AX和DX的内容是什么?

答:(1) 见注释;

(2) 见注释;

(3) (AX)=8D00H,(DX)=0

3.19下列程序段中的每条指令执行完后,AX寄存器及CF、SF、ZF和OF的内容是什么?

MOV AX, 0 ;(AX)=0, 标志位不变

DEC AX ;(AX)=0FFFFH, CF不变,SF=1,ZF=0,OF=0

ADD AX, 7FFFH ;(AX)=7FFEH, CF=1,SF=0,ZF=0,OF=0

ADD AX, 2 ;(AX)=8000H, CF=0,SF=1,ZF=0,OF=1

NOT AX ;(AX)=7FFFH, 标志位不变

SUB AX, 0FFFFH ;(AX)=8000H, CF=1,SF=1,ZF=0,OF=1

ADD AX, 8000H ;(AX)=0,CF=1,SF=0,ZF=1,OF=1

SUB AX, 1 ;(AX)=0FFFFH, CF=1,SF=1,ZF=0,OF=0

AND AX, 58D1H ;(AX)=58D1H, CF=0,SF=0,ZF=0,OF=0

SAL AX, 1 ;(AX)=0B1A2H, CF=0,SF=1,ZF=0,OF=1

SAR AX, 1 ;(AX)=0D8D1H, CF=0,SF=1,ZF=0,OF=0

NEG AX ;(AX)= 272FH, CF=1,SF=0,ZF=0,OF=0

ROR AX, 1 ;(AX)= 9397H, CF=1,SF和ZF不变,OF=1

答:见注释。

3.20变量DA TAX和变量DATAY的定义如下:

DA TAX DW 0148H

DW 2316H

DA TAY DW 0237H

DW 4052H

请按下列要求写出指令序列:

(1) DA TAX和DATAY两个字数据相加,和存放在DA TAY中。

(2) DA TAX和DATAY两个双字数据相加,和存放在从DATAY开始的双字单元中。

(3) 解释下列指令的作用:

STC

MOV BX, DA TAX

ADC BX, DA TAY

(4) DA TAX和DATAY两个字数据相乘(用MUL)。

(5) DA TAX和DATAY两个双字数据相乘(用MUL)。

(6) DA TAX除以23(用DIV)。

(7) DA TAX双字除以字DA TAY (用DIV)。

答:(1) MOV AX, DATAX

ADD DA TAY, AX

MOV AX, DA TAX+2

ADD DA TAY+2, AX

(2) MOV AX, DA TAX

ADD DA TAY, AX

MOV AX, DA TAX+2

ADC DATAY+2, AX

MOV DA TAY+4, 0 ;用于存放进位位

ADC DATAY+4, 0

(3) DATAX和DATAY两个字数据之和加1,结果存入BX寄存器。

(4) RESULT1 DW 0

DW 0

RESULT2 DW 0

DW 0

MOV AX, DA TAX

MUL DATAY

MOV RESULT1 , AX

MOV RESULT1+2, DX

MOV AX, DA TAX+2

MUL DATAY+2

MOV RESULT2 , AX

MOV RESULT2+2, DX

(5) AA DW 0

BB DW 0

CC DW 0

DD DW 0

MOV AX, DA TAX

MUL DATAY

MOV AA , AX

MOV BB, DX

MOV AX, DA TAX

MUL DATAY+2

ADD BB, AX

ADC CC, DX

MOV AX, DA TAX+2

MUL DATAY

ADD BB, AX

ADC CC, DX

ADC DD, 0

MOV AX, DA TAX+2

MUL DATAY+2

ADD CC, AX

ADC DD, DX

(6) MOV AX, DA TAX

MOV BL, 23

DIV BL

(7) MOV DX, DA TAX+2

MOV AX, DA TAX

DIV DATAY

3.21写出对存放在DX和AX中的双字长数求补的指令序列。

答:NEG DX 也可为:NOT DX

NEG AX NOT AX

SBB DX, 0 ADD AX, 1

ADC DX, 0

3.22试编写一程序求出双字长数的绝对值。双字长数在A和A+2单元中,结果存放在B和B+2单元

中。

答:程序段如下:

MOV AX, A

MOV DX, A+2

CMP DX, 0

JNS ZHENSHU ;不是负数则转走

NEG DX

NEG AX

SBB DX, 0

ZHENSHU: MOV B, AX

MOV B+2, DX

INT 20H

3.23假设(BX)=0E3H,变量V ALUE中存放的内容为79H,确定下列各条指令单独执行后的结果。

(1) XOR BX, V ALUE ;(BX)=9AH,CF、OF都为0,AF无定义,SF=1,ZF=0,PF=1

(2) AND BX, V ALUE ;(BX)=61H,CF、OF都为0,AF无定义,SF=0,ZF=0,PF=0

(3) OR BX, V ALUE ;(BX)=0FBH,CF、OF都为0,AF无定义,SF=1,ZF=0,PF=0

(4) XOR BX, 0FFH ;(BX)=1CH,CF、OF都为0,AF无定义,SF=0,ZF=0,PF=0

(5) AND BX, 0 ;(BX)=00H,CF、OF都为0,AF无定义,SF=0,ZF=1,PF=1

(6) TEST BX, 01H ;(BX)=0E3H,CF、OF都为0,AF无定义,SF=1,ZF=0,PF=0

答:见注释。

3.24试写出执行下列指令序列后BX寄存器的内容。执行前(BX)=6D16H。

MOV CL, 7

SHR BX, CL

答:(BX)=00DAH。

3.25试用移位指令把十进制数+53和-49分别乘以2。它们应该用什么指令?得到的结果是什么?如果

要除以2呢?

答:MOV AL, 53

SAL AL, 1 ;(AL)=(+53*2)=6AH

MOV AL, -49

SAL AL, 1 ;(AL)=(-49*2)=9EH

MOV AL, 53

SAR AL, 1 ;(AL)=(53/2)= 1AH

MOV AL, -49

SAR AL, 1 ;(AL)=(-49/2)=0E7H

3.26试分析下面的程序段完成什么功能?

MOV CL, 04

SHL DX, CL

MOV BL, AH

SHL AX, CL

SHR BL, CL

OR DL, BL

答:本程序段将((DX),(AX)) 的双字同时左移4位,即将此双字乘以10H (16)。

3.27假定(DX)=0B9H,(CL)=3,(CF)=1,确定下列各条指令单独执行后DX中的值。

(1) SHR DX, 1 ;(DX)=05CH

(2) SAR DX, CL ;(DX)=17H

(3) SHL DX, CL ;(DX)=5C8H

(4) SHL DL, 1 ;(DX)=72H

(5) ROR DX, CL ;(DX)=2017H

(6) ROL DL, CL ;(DX)=0CDH

(7) SAL DH, 1 ;(DX)=0B9H

(8) RCL DX, CL ;(DX)=2CCH

(4) RCR DL, 1 ;(DX)=0DCH

答:见注释。

3.28下列程序段执行完后,BX寄存器的内容是什么?

MOV CL, 3

MOV BX, 0B7H

ROL BX,1

ROR BX, CL

答:(BX)=0C02DH。

3.29假设数据段定义如下:

CONAME DB ?SPACE EXPLORERS INC.‘

PRLINE DB 20 DUP (?‘)

用串指令编写程序段分别完成以下功能:

(1) 从左到右把CONAME中的字符串传送到PRLINE。

(2) 从右到左把CONAME中的字符串传送到PRLINE。

(3) 把CONAME中的第3和第4个字节装入AX。

(4) 把AX寄存器的内容存入从PRLINE+5开始的字节中。

(5) 检查CONAME字符串中有无空格字符,如有则把第一个空格字符的地址传送给BX寄存器。

答:(1) MOV CX, 20

CLD

MOV SI, SEG CONAME

MOV DS, SI

MOV ES, SI

LEA SI, CONAME

LEA DI, PRLINE

REP MOVSB

(2) MOV CX, 20

STD

MOV SI, SEG CONAME

MOV DS, SI

MOV ES, SI

LEA SI, CONAME

ADD SI, 20-1

LEA DI, PRLINE

ADD DI, 20-1

REP MOVSB

(3) MOV AX, WORD PTR CONAME+3-1

(4) MOV WORD PTR PRLINE +5, AX

(5) MOV AL, ?‘;空格的ASCII码送AL寄存器

CLD

MOV DI, SEG CONAME

MOV ES, DI

LEA DI, CONAME

REPNE SCASB

JNE NEXT

DEC DI

MOV BX, DI

NEXT: ┇

3.30编写程序段,把字符串STRING中的?&‘字符用空格符代替。

STRING DB ?The date is FEB&03‘

答:程序段如下:

MOV CX, 18

MOV AL, ?&‘

CLD

MOV DI, SEG STRING

MOV ES, DI

LEA DI, STRING

REPNE SCASB

JNE NEXT

DEC DI

MOV ES:BYTE PTR [DI], ?‘;送空格符

NEXT: ┇

3.31假设数据段中数据定义如下:

STUDENT_NAME DB 30 DUP (?)

STUDENT_ADDR DB 9 DUP (?)

PRINT_LINE DB 132 DUP (?)

分别编写下列程序段:

(1) 用空格符清除PRINT_LINE域。

(2) 在STUDENT_ADDR中查找第一个?-‘。

(3) 在STUDENT_ADDR中查找最后一个?-‘。

(4) 如果STUDENT_NAME域中全是空格符时,填入?*‘。

(5) 把STUDENT_NAME移到PRINT_LINE的前30个字节中,把STUDENT_ ADDR移到

PRINT_LINE的后9个字节中。

答:公共的程序段如下:

MOV DI, DS

MOV ES, DI

(1) MOV CX, 132

MOV AL., ?‘;空格的ASCII码送AL寄存器

CLD

LEA DI, PRINT_LINE

REP STOSB

(2) MOV CX, 9

MOV AL., ?-‘

CLD

LEA DI, STUDENT_ ADDR

REPNE SCASB

JNE NO_DASH

DEC DI

NO_DASH: ┇

(3) MOV CX, 9

MOV AL., ?-‘

STD

LEA DI, STUDENT_ ADDR

ADD DI, 9-1

REPNE SCASB

JNE NO_DASH

INC DI

NO_DASH: ┇

(4) MOV CX, 30

MOV AL, ?‘;空格的ASCII码送AL寄存器

CLD

LEA DI, STUDENT_NAME

REPE SCASB

JNE NEXT

MOV CX, 30

MOV AL, ?*‘;―*‖的ASCII码送AL寄存器

LEA DI, STUDENT_NAME

REP STOSB

NEXT: ┇

(5) MOV CX, 30

CLD

LEA SI, STUDENT_NAME

LEA DI, PRINT_LINE

REP MOVSB

MOV CX, 9

STD

LEA SI, STUDENT_ADDR+9-1

LEA DI, PRINT_LINE+132-1

REP MOVSB

3.32编写一程序段:比较两个5字节的字符串OLDS和NEWS,如果OLDS字符串不同于NEWS字符

串则执行NEW_LESS;否则顺序执行程序。

答:程序段如下:

MOV CX, 5

CLD

MOV DI, SEG OLDS

MOV DS, DI

MOV ES, DI

LEA SI, OLDS

LEA DI, NEWS

REPE CMPSB

JNE NEW_LESS

NEW_LESS: ┇

3.33假定AX和BX中的内容为带符号数,CX和DX中的内容为无符号数,请用比较指令和条件转移

指令实现以下判断:

(1) 若DX的内容超过CX的内容,则转去执行EXCEED。

(2) 若BX的内容大于AX的内容,则转去执行EXCEED。

(3) 若CX的内容等于0,则转去执行ZERO。

(4)BX与AX的内容相比较是否产生溢出?若溢出则转OVERFLOW。

(5) 若BX的内容小于等于AX的内容,则转EQ_SMA。

(6) 若DX的内容低于等于CX的内容,则转EQ_SMA。

答:(1) CMP DX, CX

JA EXCEED

(2) CMP BX, AX

JG EXCEED

(3) JCXZ ZERO

(4) CMP BX, AX

JO OVERFLOW

(5) CMP BX, AX

JLE EQ_SMA

(6) CMP DX, CX

JBE EQ_SMA

3.34试分析下列程序段:

ADD AX, BX

JNO L1

JNC L2

SUB AX, BX

JNC L3

JNO L4

JMP SHORT L5

如果AX和BX的内容给定如下:

AX BX

(1) 147BH 80DCH

(2) B568H 42C8H

(3) 42C8H 608DH

(4) D023H 9FD0H

(5) 94B7H B568H

问该程序分别在上面5种情况下执行后,程序转向哪里?

答:(1) 转向L1

(2) 转向L1

(3) 转向L2

(4) 转向L5 ;因为加法指令后AX中已经是6FF3H

(5) 转向L5 ;因为加法指令后AX中已经是4A14H

3.35指令CMP AX, BX后面跟着一条格式为J…L1的条件转移指令,其中…可以是B、NB、BE、

NBE、L、NL、LE、NLE中的任意一个。如果AX和BX的内容给定如下:

AX BX

(1) 1F52H 1F52H

(2) 88C9H 88C9H

(3) FF82H 007EH

(4) 58BAH 020EH

(5) FFC5H FF8BH

(6) 09A0H 1E97H

(7) 8AEAH FC29H

(8) D367H 32A6H

问以上8条转移指令中的哪几条将引起转移到L1?

答:(1) JNB、JBE、JNL、JLE

(2) JNB、JBE、JNL、JLE

(3) JNB、JNBE、JL、JLE

(4) JNB、JNBE、JNL、JNLE

(5) JNB、JNBE、JL、JLE

(6) JB、JBE、JL、JLE

(7) JB、JBE、JNL、JNLE

(8) JNB、JNBE、JL、JLE

3.36假设X和X+2单元的内容为双精度数p,Y和Y+2单元的内容为双精度数q,(X和Y为低位字)

试说明下列程序段做什么工作?

MOV DX, X+2

MOV AX, X

ADD AX, X

ADC DX, X+2

CMP DX, Y+2

JL L2

JG L1

CMP AX, Y

JBE L2

L1:MOV AX, 1

JMP SHORT EXIT

L2:MOV AX, 2

EXIT:INT 20H

答:此程序段判断p*2>q,则使(AX)=1后退出;p*2≤q,则使(AX)=2后退出。

3.37要求测试在STATUS中的一个字节,如果第1、3、5位均为1则转移到ROUTINE_1;如果此三位

中有两位为1则转移到ROUTINE_2;如果此三位中只有一位为1则转移到ROUTINE_3;如果此三位全为0则转移到ROUTINE_4。试画出流程图,并编制相应的程序段。

答:程序段如下:

AND AL, 00010101B ;只保留第1、3、

JZ ROUTINE_4 ;3位全为0转

JPE ROUTINE_2 ;两位为1转

CMP AL, 00010101B

JZ ROUTINE_1 ;3位全为1转

ROUTINE_3:┇;仅一位为1执行

JMP EXIT

ROUTINE_1:┇

JMP EXIT

ROUTINE_2:┇

JMP EXIT

ROUTINE_4:┇

EXIT: INT 20H

3.38在下列程序的括号中分别填入如下指令:

(1) LOOP L20

(2) LOOPE L20

(3) LOOPNE L20

试说明在三种情况下,当程序执行完后,AX、

CX、DX四个寄存器的内容分别是什么?

3.44题的程序流程图

TITLE https://www.wendangku.net/doc/0f6102950.html,

CODESG SEGMENT

ASSUME CS:CODESG, DS: CODSEG, SS: CODSEG

ORG 100H

BEGIN: MOV AX, 01

MOV BX, 02

MOV DX, 03

MOV CX, 04

L20:

INC AX ADD BX, AX SHR DX, 1 ( ) RET

CODESG ENDS

END BEGIN

答:(1) (AX)=5H ,(BX)=10H ,(CX)=0H ,(DX)=0H

(2) (AX)=2H ,(BX)=4H ,(CX)=3H ,(DX)=1H (3) (AX)=3H ,(BX)=7H ,(CX)=2H ,(DX)=0H

3.39 考虑以下的调用序列:

(1) MAIN 调用NEAR 的SUBA 过程(返回的偏移地址为0400); (2) SUBA 调用NEAR 的SUBB 过程(返回的偏移地址为0A00);

(3) SUBB 调用FAR 的SUBC 过程(返回的段地址为B200,返回的偏移地址为0100); (4) 从SUBC 返回SUBB ;

(5) SUBB 调用NEAR 的SUBD 过程(返回的偏移地址为0C00); (6) 从SUBD 返回SUBB ; (7) 从SUBB 返回SUBA ; (8) 从SUBA 返回MAIN ;

(9) 从MAIN 调用SUBC(返回的段地址为1000,返回的偏移地址为0600); 请画出每次调用及返回时的堆栈状态。

答:每次调用及返回时的堆栈状态图如下所示:

3.40 假设(EAX)=00001000H ,(EBX)=00002000H ,(DS)=0010H ,试问下列指令访问内存的物理地址是

什么?

(1) MOV ECX ,[EAX+EBX] (2) MOV [EAX+2*EBX],CL

(3) MOV DH ,[EBX+4*EAX+1000H]

答:(1) PA=(DS)*10H+EA=00100H+00001000H+00002000H=00003100H

(2) PA=(DS)*10H+EA=00100H+00001000H+2*00002000H=00005100H

(3) PA=(DS)*10H+EA=00100H+00002000H+4*00001000H+1000H=00007100H 3.41 假设(EAX)=9823F456H ,(ECX)=1F23491H ,(BX)=348CH ,(SI)=2000H ,(DI)=4044H 。在DS 段中

从偏移地址4044H 单元开始的4个字节单元中,依次存放的内容为92H ,6DH ,0A2H 和4CH ,试问下列各条指令执行完后的目的地址及其中的内容是什么? (1) MOV [SI],EAX

00 04 原SP 位置 新SP 位置 (1) MAIN 调 用SUBA 过程 00 0A 00 04 原SP 位置 新SP 位置 (2) SUBA 调 用SUBB 过程 00 01 00 B2 00 0A 00 原SP 位置 新SP 位置 (3) SUBB 调 用SUBC 过程 00 01

00 B2 00 0A 00 原SP 位置 新SP 位置 (4) 从SUBC 返回SUBB

00 01 00 0C 00 0A 00 04 原SP 位置 新SP 位置 (5) SUBB 调 用SUBD 过程 00 01 00 0C 00 0A 00 04 原SP 位置 新SP 位置 (6) 从SUBD 返回SUBB 00 01 00 0C 00 0A 00 04 原SP 位置 新SP 位置 (7) 从SUBB 返回SUBA 00 01 00 0C 00 0A 00 04 原SP 位置 新SP 位置 (8) 从SUBA 返回MAIN 00 01 00 0C 00 06 00 10 原SP 位置

新SP 位置 (9) 从MAIN

调用SUBC

(2) MOV [BX],ECX

(3) MOV EBX,[DI]

答:(1) 目的地址为DS:2000H,内容依次为:56H,0F4H,23H和98H

(2) 目的地址为DS:348CH,内容依次为:91H,34H,0F2H和01H

(3) 目的操作数为EBX寄存器,(EBX)=4CA26D92H

3.42说明下列指令的操作

(1) PUSH AX ;将(AX)压入堆栈

(2) POP ESI ;将堆栈中的双字弹出到ESI寄存器中

(3) PUSH [BX] ;将((BX))对应存储单元中的字压入堆栈

(4) PUSHAD ;32位通用寄存器依次进栈

(5) POP DS ;将堆栈中的字弹出到DS寄存器中

(6) PUSH 4 ;将立即数4以字的方式压入堆栈

答:见注释。

3.43请给出下列各指令序列执行完后目的寄存器的内容。

(1) MOV EAX,299FF94H

ADD EAX,34FFFFH ;(EAX)= 2CEFF93H

(2) MOV EBX,40000000

SUB EBX,1500000 ;(EBX)= 3EB00000H

(3) MOV EAX,39393834H

AND EAX,0F0F0F0FH ;(EAX)= 09090804H

(4) MOV EDX,9FE35DH

XOR EDX,0F0F0F0H ;(EDX)= 6F13ADH

答:见注释。

3.44请给出下列各指令序列执行完后目的寄存器的内容。

(1) MOV BX,-12

MOVSX EBX,BX ;(EBX)= 0FFFF FFF4H

(2) MOV CL,-8

MOVSX EDX,CL ;(EDX)= 0FFFF FFF8H

(3) MOV AH,7

MOVZX ECX,AH ;(ECX)= 0000 0007H

(4) MOV AX,99H

MOVZX EBX,AX ;(EBX)= 0000 0099H

答:见注释。

3.45请给出下列指令序列执行完后EAX和EBX的内容。

MOV ECX,307 F455H

BSF EAX,ECX ;(EAX)= 0D

BSR EBX,ECX ;(EBX)= 25D

答:见注释。

3.46请给出下列指令序列执行完后AX和DX的内容。

MOV BX,98H

BSF AX,BX ;(AX)= 3D

BSR DX,BX ;(DX)= 7D

答:见注释。

3.47请编写一程序段,要求把ECX、EDX和ESI的内容相加,其和存入EDI寄存器中(不考虑溢出)。

答:MOV EDI,0 也可为:MOV EDI,ECX

ADD EDI,ECX ADD EDI,EDX

ADD EDI,EDX ADD EDI,ESI

ADD EDI,ESI

3.48请说明IMUL BX,DX,100H指令的操作。

答:(BX)←(DX)*100H

3.49 试编写一程序段,要求把BL 中的数除以CL 中的数,并把其商乘以2,最后的结果存入DX 寄存

器中。

答:MOV AL ,BL

MOV AH ,0 ;假定为无符号数,否则用CBW 指令即可 DIV CL MOV AH ,0 SHL AX ,1 MOV DX ,AX 3.50 请说明JMP DI 和JMP [DI]指令的区别。

答:JMP DI 是转移到以(DI)内容为偏移地址的单元去执行指令;JMP [DI]是转移到以(DI)间接

寻址的内存单元内容为偏移地址的单元去执行指令。 3.51 试编写一程序段,要求在长度为100H 字节的数组中,找出大于42H 的无符号数的个数并存入字

节单元UP 中;找出小于42H 的无符号数的个数并存入字节单元DOWN 中。 答:JMP BEGIN

UP DB 0 DOWN DB 0 TABLE DB 100H DUP (?) ;数组 BEGIN :

MOV CX ,100H

MOV BX ,-1

MOV SI ,0

MOV DI ,0

L1:INC BX CMP TABLE[BX],42H JA L2 JB L3 JMP L4 L2:INC SI JMP L4 L3:INC DI

L4:LOOP L1

MOV UP ,SI

MOV DOWN ,DI

3.52 请用图表示ENTER 16,0所生成的堆栈帧的情况。

答:答案见右图。

第 四 章. 习 题

4.1 指出下列指令的错误:

(1) MOV AH, BX ;寄存器类型不匹配 (2) MOV [BX], [SI] ;不能都是存储器操作数 (3) MOV AX, [SI][DI] ;[SI]和[DI]不能一起使用 (4) MOV MYDAT [BX][SI], ES:AX ;AX 寄存器不能使用段超越 (5) MOV BYTE PTR [BX], 1000 ;1000超过了一个字节的范围

(6) MOV BX, OFFSET MYDA T [SI] ;MYDAT [SI]已经是偏移地址,不能再使用OFFSET (7) MOV CS, AX ;CS 不能用作目的寄存器 (8) MOV ECX, AX

;两个操作数的数据类型不同

答:见注释。

4.2 下面哪些指令是非法的?(假设OP1,OP2是已经用DB 定义的变量)

(1) CMP 15, BX ;错,立即数不能作为目的操作数 (2) CMP OP1, 25

002EH 002FH 0030H 0031H 0032H 0033H 0034H 0035H 0036H 0037H 0038H 0039H 003AH 003BH 003CH 003DH 堆栈帧 原新新

(3) CMP OP1, OP2 ;错,不能都是存储器操作数

(4) CMP AX, OP1 ;错,类型不匹配,应为CMP ax, word ptr op1

答:见注释。

4.3 假设下列指令中的所有标识符均为类型属性为字的变量,请指出下列哪些指令是非法的?它们的

错误是什么?

(1) MOV BP, AL ;错,寄存器类型不匹配 (2) MOV WORD_OP [BX+4*3][DI], SP (3) MOV WORD_OP1, WORD_OP2 ;错,不能都是存储器操作数 (4) MOV AX, WORD_OP1[DX] ;错,DX 不能用于存储器寻址 (5) MOV SA VE_WORD, DS

(6) MOV SP, SS:DATA_WORD [BX][SI] (7) MOV [BX][SI], 2 ;错,[BX][SI]未指出数据类型 (8) MOV AX, WORD_OP1+WORD_OP2 (9) MOV AX, WORD_OP1-WORD_OP2+100 (10) MOV WORD_OP1, WORD_OP1-WORD_OP2 答:见注释。 4.4 假设V AR1和V AR2为字变量,LAB 为标号,试指出下列指令的错误之处:

(1) ADD V AR1, V AR2 ;不能都是存储器操作数 (2) SUB AL, V AR1 ;数据类型不匹配 (3) JMP LAB [SI] ;LAB 是标号而不是变量名,后面不能加[SI] (4) JNZ V AR1 ;VAR1是变量而不是标号 (5) JMP NEAR LAB ;应使用NEAR PTR 答:见注释。 4.5 画图说明下列语句所分配的存储空间及初始化的数据值。

(1) BYTE_V AR DB ?BYTE ‘,12,-12H,3 DUP(0,?,2 DUP(1,2),?) (2) WORD_VAR DW 5 DUP(0,1,2),?,-5,?BY ‘,?TE ‘,256H 答:答案如下图所示。

4.6 试列出各种方法,使汇编程序把5150H 存入一个存储器字中(如:DW 5150H)。

答:DW 5150H

DB 50H, 51H

DB ?PQ ‘

DW ?QP ‘

ORG 5150H

DW $

4.7 请设置一个数据段DA TASG ,其中定义以下字符变量或数据变量。 (1) FLD1B 为字符串变量:?personal computer ‘; (2) FLD2B 为十进制数字节变量:32; (3) FLD3B 为十六进制数字节变量:20;

(4) FLD4B 为二进制数字节变量:01011001;

(5) FLD5B 为数字的ASCII 字符字节变量:32654;

(6) FLD6B 为10个零的字节变量;

(7) FLD7B 为零件名(ASCII 码)及其数量(十进制数)的表格: PART1 20 PART2 50 PART3 14 (8) FLD1W 为十六进制数字变量:FFF0; (9) FLD2W 为二进制数的字变量:01011001; (10) FLD3W 为(7)零件表的地址变量;

(11) FLD4W 为包括5个十进制数的字变量:5,6,7,8,9;

4.5题答案

42H 59H 54H 45H 0DH EEH 00H - 01H 02H

01H

02H -

00H - 01H 02H

01H

02H

- BYTE_V AR 00H 00H 01H 00H 02H 00H ┇ ┇ ┇ - - FBH FFH 00H 59H 42H 45H 54H 56H 02H

WORD_V AR 将上面 内容再 重复4次

(12) FLD5W为5个零的字变量;

(13) FLD6W为本段中字数据变量和字节数据变量之间的地址差。

答:DA TASG SEGMENT

FLD1B DB ?personal computer‘

FLD2B DB 32

FLD3B DB 20H

FLD4B DB 01011001B

FLD5B DB ?32654‘

FLD6B DB 10DUP (0)

FLD7B DB ?PART1‘, 20

DB ?PART2‘, 50

DB ?PART3‘, 14

FLD1W DW 0FFF0H

FLD2W DW 01011001B

FLD3W DW FLD7B

FLD4W DW 5, 6, 7, 8, 9

FLD5W DW 5 DUP (0)

FLD6W DW FLD1W-FLD1B

DA TASG ENDS

4.8假设程序中的数据定义如下:

PARTNO DW ?

PNAME DB 16 DUP (?)

COUNT DD ?

PLENTH EQU $-PARTNO

问PLENTH的值为多少?它表示什么意义?

答:PLENTH=22=16H,它表示变量PARTNO、PNAME、COUNT总共占用的存储单元数(字节数)。

4.9有符号定义语句如下:

BUFF DB 1, 2, 3, ?123‘

EBUFF DB 0

L EQU EBUFF - BUFF

问L的值是多少?

答:L=6。

4.10假设程序中的数据定义如下:

LNAME DB 30 DUP (?)

ADDRESS DB 30 DUP (?)

CITY DB 15 DUP (?)

CODE_LIST DB 1, 7, 8, 3, 2

(1) 用一条MOV指令将LNAME的偏移地址放入AX。

(2) 用一条指令将CODE_LIST的头两个字节的内容放入SI。

(3) 用一条伪操作使CODE_LENGTH的值等于CODE_LIST域的实际长度。

答:(1) MOV AX, OFFSET LNAME

(2) MOV SI, WORD PTR CODE_LIST

(3) CODE_LENGTH EQU $ - CODE_LIST ;此语句必须放在CODE_LIST语句之后

4.11试写出一个完整的数据段DA TA_SEG,它把整数5赋予一个字节,并把整数-1,0,2,5和4放

在10字数组DATA_LIST的头5个单元中。然后,写出完整的代码段,其功能为:把DATA_LIST 中头5个数中的最大值和最小值分别存入MAX和MIN单元中。

答:DA TA_SEG SEGMENT

NUM DB 5

DATA_LIST DW -1, 0, 2, 5, 4, 5 DUP (?)

MAX DW ?

MIN DW ?

DA TA_SEG ENDS

;----------------------------------------------------------------

CODE_SEG SEGMENT

MAIN PROC FAR

ASSUME CS: CODE_SEG, DS: DATA_SEG

START: PUSH DS ;设置返回DOS

SUB AX, AX

PUSH AX

MOV AX, DA TA_SEG ;给DS赋值

MOV DS, AX

MOV CX, 4 ;程序段开始

LEA BX, DA TA_LIST

MOV AX, [BX]

MOV MAX, AX

MOV MIN, AX

ROUT1: ADD BX, 2

MOV AX, [BX]

CMP AX, MAX

JNGE ROUT2

MOV MAX, AX

ROUT2: CMP AX, MIN

JNLE ROUT3

MOV MIN, AX

ROUT3: LOOP ROUT1 ;程序段结束

RET

MAIN ENDP

CODE_SEG ENDS

;----------------------------------------------------------------

END START

4.12给出等值语句如下:

ALPHA EQU 100

BETA EQU 25

GAMMA EQU 2

下列表达式的值是多少?

(1) ALPHA * 100 + BETA ;=2729H

(2) ALPHA MOD GAMMA + BETA ;=19H

(3) (ALPHA +2) * BETA – 2 ;=9F4H

(4) (BETA / 3) MOD 5 ;=3H

(5) (ALPHA +3) * (BETA MOD GAMMA) ;=67H

(6) ALPHA GE GAMMA ;=0FFFFH

(7) BETA AND 7 ;=01H

(8) GAMMA OR 3 ;=03H

答:见注释。

4.13对于下面的数据定义,三条MOV指令分别汇编成什么?(可用立即数方式表示)

TABLEA DW 10 DUP (?)

TABLEB DB 10 DUP (?)

TABLEC DB ?1234‘

MOV AX, LENGTH TABLEA ;汇编成MOV AX, 000AH MOV BL, LENGTH TABLEB ;汇编成MOV BL, 000AH

MOV CL, LENGTH TABLEC ;汇编成MOV CL, 0001H 答:见注释。

4.14对于下面的数据定义,各条MOV指令单独执行后,有关寄存器的内容是什么?

FLDB DB ?

TABLEA DW 20 DUP (?)

TABLEB DB ?ABCD‘

(1) MOV AX, TYPE FLDB ;(AX)=0001H

(2) MOV AX, TYPE TABLEA ;(AX)=0002H

(3) MOV CX, LENGTH TABLEA ;(CX)=0014H

(4) MOV DX, SIZE TABLEA ;(DX)=0028H

(5) MOV CX, LENGTH TABLEB ;(CX)=0001H

答:见注释。

4.15指出下列伪操作表达方式的错误,并改正之。

(1) DATA_SEG SEG ;DATA_SEG S EGMENT(伪操作错)

(2) SEGMENT ?CODE‘;SEGNAME SEGMENT ?CODE‘(缺少段名字)

(3) MYDATA SEGMENT/DATA ;MYDATA SEGMENT

ENDS ;MYDATA ENDS(缺少段名字)

(4) MAIN_PROC P ROC FAR ;删除END MAIN_PROC也可以

END MAIN_PROC ;MAIN_PROC ENDP ;上下两句交换位置MAIN_PROC ENDP ;END MAIN_PROC 答:见注释。

4.16按下面的要求写出程序的框架

(1) 数据段的位置从0E000H开始,数据段中定义一个100字节的数组,其类型属性既是字又是字

节;

(2) 堆栈段从小段开始,段组名为STACK;

(3) 代码段中指定段寄存器,指定主程序从1000H开始,给有关段寄存器赋值;

(4) 程序结束。

答:程序的框架如下:

DA TA_SEG SEGMENT AT 0E000H

ARRAY_B LABEL BYTE

ARRAY_W DW 50 DUP (?)

DA TA_SEG ENDS ;以上定义数据段

;----------------------------------------------------------------

STACK_SEG SEGMENT PARA STACK ?STACK‘

DW 100H DUP (?)

TOS LABEL WORD

STACK_SEG ENDS ;以上定义堆栈段

;----------------------------------------------------------------

CODE_SEG SEGMENT

MAIN PROC FAR

ASSUME CS: CODE_SEG, DS: DATA_SEG, SS: STACK_SEG

ORG 1000H

START: MOV AX, STACK_SEG

MOV SS, AX ;给SS赋值

MOV SP, OFFSET TOS ;给SP赋值

PUSH DS ;设置返回DOS

SUB AX, AX

PUSH AX

MOV AX, DA TA_SEG

MOV DS, AX ;给DS赋值

┇;程序段部分

RET

MAIN ENDP

CODE_SEG ENDS ;以上定义代码段

;----------------------------------------------------------------

END START

4.17写一个完整的程序放在代码段C_SEG中,要求把数据段D_SEG中的AUGEND和附加段E_SEG

中的ADDEND相加,并把结果存放在D_SEG 段中的SUM中。其中AUGEND、ADDEND和SUM 均为双精度数,AUGEND赋值为99251,ADDEND赋值为-15962。

答:程序如下:

80x86汇编语言程序设计教程》(清华大学出版社,黑色封面,杨季文著)

80x86汇编语言程序设计教程》(清华大学出版社,黑色封面,杨季文著) 《计算机操作系统原理》 《Inside Windows 2000》(微软出版社,我看的是E文版的,中文的书名想必是Windows 2000 技术内幕之类吧)。 《数据结构和算法》——这门课程能够决定一个人程序设计水平的高低,是一门核心课程。我首选的是清华版的(朱战立,刘天时) 《软件工程》——这门课程是越到后来就越发现它的重要,虽然刚开始看时就象看马哲一样不知所云。我的建议是看《实用软件工程》(黄色,清华) 《Windows 程序设计》——《北京大学出版社,Petzold著》我建议任何企图设计Windows 程序的人在学习VC以前仔细的学完它。而且前面的那本 建议:你还可以在CSDN上阅读到许多书评。这些书评能够帮助你决定读什么样的书 关于编程的网站 计算机编程 郭新明-FTP服务器体验式学习课程(张孝祥监制) https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=3997 https://www.wendangku.net/doc/0f6102950.html,快速开发新闻系统在线播放 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=4708 数字电路基础[宁波电大] https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=774 计算机组成与汇编语言程序设计(赵丽梅)宁波电大 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=1242 操作系统(陈访荣)宁波电大(在线播放) https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=4708 计算机网络(马敏飞)宁波电大 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=1243 https://www.wendangku.net/doc/0f6102950.html, 2.0快速入门(12)-https://www.wendangku.net/doc/0f6102950.html, 2.0网站快速导航 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=2501 Internet和Intranet应用(薛昭旺)宁波电大 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=1245 2004年电脑硬件安装调试维修视频教学讲授 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=4825 https://www.wendangku.net/doc/0f6102950.html, 高级排错技巧 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=768 SQL Server 2000管理专家系列课程 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=4832 开心三人行系列(2):使用Atlas 构建AJAX应用 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=2564 Visual Basic 2005开发技巧系列课程(4): 在Visual Basic 2005中使用.NET Framework 2.0新增功能 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=2526 SQL Server 2005 系列课程-使用ADO https://www.wendangku.net/doc/0f6102950.html,开发SQL Server 2005 OLAP应用 https://www.wendangku.net/doc/0f6102950.html,/so/so138.aspx?id=2535

《运筹学》课后习题答案

第一章线性规划1、 由图可得:最优解为 2、用图解法求解线性规划: Min z=2x1+x2 ? ? ? ? ? ? ? ≥ ≤ ≤ ≥ + ≤ + - 10 5 8 24 4 2 1 2 1 2 1 x x x x x x 解: 由图可得:最优解x=1.6,y=6.4

Max z=5x 1+6x 2 ? ?? ??≥≤+-≥-0 ,23222212 121x x x x x x 解: 由图可得:最优解Max z=5x 1+6x 2, Max z= + ∞

Maxz = 2x 1 +x 2 ????? ? ?≥≤+≤+≤0,5242261552121211x x x x x x x 由图可得:最大值?????==+35121x x x , 所以?????==2 3 21x x max Z = 8.

12 12125.max 2328416412 0,1,2maxZ .j Z x x x x x x x j =+?+≤? ≤?? ≤??≥=?如图所示,在(4,2)这一点达到最大值为2 6将线性规划模型化成标准形式: Min z=x 1-2x 2+3x 3 ????? ??≥≥-=++-≥+-≤++无约束 321 321321321,0,05232 7x x x x x x x x x x x x 解:令Z ’=-Z,引进松弛变量x 4≥0,引入剩余变量x 5≥0,并令x 3=x 3’-x 3’’,其中x 3’≥ 0,x 3’’≥0 Max z ’=-x 1+2x 2-3x 3’+3x 3’’ ????? ? ?≥≥≥≥≥≥-=++-=--+-=+-++0 ,0,0'',0',0,05 232 '''7'''543321 3215332143321x x x x x x x x x x x x x x x x x x x

清华大学2006数学分析真题参考答案

清华大学2006数学分析真题参考答案 1.若数列{}n x 满足条件11221n n n n x x x x x x M ----+-++-≤g g g 则称{}n x 为有界变差数列,证:令10y =,11221n n n n n y x x x x x x ---=-+-++-g g g (n=2,3,….) 那么{}n y 单调递增,由条件知{}n y 有界, {}n y ∴收敛 ,从而0,0N ε?>?>,使当n m N >>时,有 n m y y ε-<,此即:11211n n n n m m x x x x x x ε---+--+-++-,考虑1()f x 和 3()f x 。 (i)若()132()()()f x f x f x <<,由于()f x 在12[,]x x 上连续,由介值定理,必存在 412[,]x x x ∈,使43()()f x f x =,定与一一映射矛盾。 (ii) ()312()()()f x f x f x <<,这时考虑23[,]x x ,必存在523[,]x x x ∈使得 51()()f x f x =,也得到矛盾。 (2)若存在123,,x x x I ∈且123x x x <<,123()()()f x f x f x ><。由介值定理,存在 412[,]x x x ∈,523[,]x x x ∈,使得42()()f x f x =,也与一一映射矛盾。 ∴f(x)在I 必严格单调。 3.证:设()f x 在(,)a b 内两个不同实根为12x x <,即12()()0f x f x ==。 由罗尔定理,存在12(,)c x x ∈,使()0f c '= (1) 因为()0f x ≥,从而为()f x 极小值点,由费马定理 12()()0f x f x ''∴== (2) 由(1),(2)对()f x '在1[,]x c 和2[,]c x 用罗尔定理,则存在3144(,),(,),x x c x c x ∈∈ 使34()()0f x f x ''''==。再一次对()f x ''在34[,]x x 上应用罗尔定理, 34[,](,)x x a b ξ?∈?,使(3)()0f ξ=。 4.证:令t=a+b-x,则 ()()()b b b a a a f x dx f a b t dt f a b x dx =+-=+-? ??。对6 a π = ,

清华大学数值分析A第一次作业

7、设y0=28,按递推公式 y n=y n?1? 1 100 783,n=1,2,… 计算y100,若取≈27.982,试问计算y100将有多大误差? 答:y100=y99?1 100783=y98?2 100 783=?=y0?100 100 783=28?783 若取783≈27.982,则y100≈28?27.982=0.018,只有2位有效数字,y100的最大误差位0.001 10、设f x=ln?(x? x2?1),它等价于f x=?ln?(x+ x2?1)。分别计算f30,开方和对数取6位有效数字。试问哪一个公式计算结果可靠?为什么? 答: x2?1≈29.9833 则对于f x=ln x?2?1,f30≈?4.09235 对于f x=?ln x+2?1,f30≈?4.09407 而f30= ln?(30?2?1) ,约为?4.09407,则f x=?ln?(x+ x2?1)计算结果更可靠。这是因为在公式f x=ln?(x? x2?1)中,存在两相近数相减(x? x2?1)的情况,导致算法数值不稳定。 11、求方程x2+62x+1=0的两个根,使它们具有四位有效数字。 答:x12=?62±622?4 2 =?31±312?1 则 x1=?31?312?1≈?31?30.98=?61.98 x2=?31+312?1= 1 31+312?1 ≈? 1 ≈?0.01613

12.(1)、计算101.1?101,要求具有4位有效数字 答:101.1?101= 101.1+101≈0.1 10.05+10.05 ≈0.004975 14、试导出计算积分I n=x n 4x+1dx 1 的一个递推公式,并讨论所得公式是否计算稳定。 答:I n=x n 4x+1dx 1 0= 1 4 4x+1x n?1?1 4 x n?1 4x+1 dx= 1 1 4 x n?1 1 dx?1 4 x n?1 4x+1 dx 1 = 1 4n ? 1 4 I n?1,n=1,2… I0= 1 dx= ln5 1 记εn为I n的误差,则由递推公式可得 εn=?1 εn?1=?=(? 1 )nε0 当n增大时,εn是减小的,故递推公式是计算稳定的。

IBM-PC汇编语言程序设计(第二版)课后习题答案(清华大学出版社)(著)答案

IBM-PC汇编语言程序设计(第二版)课后习题答案(清华大学出版社)(沈美明,温冬蝉著)答案 第三章答案1-22 1. (1)立即寻址没有 (2)直接寻址 7237H (3)使用BX的寄存器寻址没有 (4)使用BX的间接寻址 637DH (5)使用BX的寄存器相对寻址 0D5F0H (6) 基址变址寻址 8E18H (7)相对基址变址 004FH 2.根据下列要求,写出相应的汇编指令。 (1)ADD DX,BX (2) ADD AL,[BX][SI] (3) ADD [BX][0B2H], CX (4) MOV AX,2A59H ADD [0524H] ,AX (5) ADD AL ,0B5H 3. (1)寄存器间接寻址 MOV BX,OFFSET [BLOCK][0AH] MOV DX ,[BX] (2)寄存器相对寻址 MOV SI,OAH MOV DX,[BLOCK][SI] (3)基址变址寻址 MOV BX ,BLOCK MOV SI,OAH MOV DX,[BX][SI] 4. 现有(DS)=2000H, (BX)=0100H, (SI)=0002H,(20100)=12H, (20101)=34H,(20102)=56H, (20103)=78H,(21200)=2AH,(20201)=4CH,(21202)=B7H,(21203)=65H,试说明下列各条指令执行完后,AX寄存器的内容。 (1)MOV AX,1200H 1200H (2) MOV AX,BX 0100H

(3) MOV AX,[1200] 4C2AH 注意,是字单元!! (4)MOV AX,[BX] 同上 (5)MOV 1100[BX] 4C2AH (6) MOV AX,[BX][SI] 7856H (7) MOV AX,1100[BX][SI] 65B7H 5.(1) 7CD9H (2) 1200H (3) 6319H 6. MOV BX,2000H LES DI ,[BX] MOV AX, ES:DI 7.转向地址OBJ的值分别为:(1)064DH (2)0691H (3)05E0H 注意有符号数的符号位 8.(1) MOV AX,0ABH 立即数寻址无物理地址 (2) MOV AX,BX 寄存器寻址同上 (3) MOV AX,[100] 直接寻址 20100H (4) MOV AX,VAL 直接寻址 20050H (5) MOV AX,[BX] 寄存器间接寻址 20100H (6) MOV AX,ES:[BX] 直接寻址 21100H (7) MOV AX,[BP] 寄存器间接寻址 20010H (8)MOV AX,[SI] 同上 200A0H (9) MOV AX,[BX+10] 寄存器相对寻址 20110H (10)MOV AX,VAL[BX] 同上 20150H (11) MOV AX,[BX][SI] 基址变址寻址 201A0H (12) MOV AX,VAL[BX][SI] 相对基相变址寻址 201F0H 9.(1)的指令: MOV AX, [BX][0CH] MOV ZREO ,AX (2) 的指令: MOV AX,ARRAY[BX] MOV ZREO,AX 10. MOV AX,TABLE 是把符号地址TABLE里的内容送到AX里,指令执行完后,(AX)=1234H LEA AX,TABLE 是把符号地址TABLE 的有效地址(这里是偏移量)送到指定寄存器AX里,指令执行完后,(AX)=0032H 11. 执行完指令后,(AX)=1E00H 12. LEA AX,CSTRING MOV DL,AX MOV DH,[AX+6] 13. 这参考课本P51--P53 14.LES BX,[2000]

清华大学运筹学考试

一、不定向选择 1、若线性规划问题有可行解则: A其可行域可能无界 B其可行域为凸集 C至少有一个可行解为基本可行解 D可行域边界上点都为基本可行解 E一定存在某一可行解使目标函数达最优值 F任一可行解均能表示为所有可行域顶点线性组合表示 G某一可行解为最优解必要条件为它是一个基本解。 2、线性规划问题和其对偶问题关系: A对偶问题的对偶问题为原问题 B若原问题无解,其对偶问题有无界解 C若原问题无界解,其对偶问题无解或者无界解 D即使原问题有最优解,其对偶问题也未必有最优解 E原问题目标函数达到最大时,其对偶问题取最小值 F只有原问题达最优解时,其对偶问题才有可行解 G若原问题有无穷多最优解,其对偶问题有无界解。 二、已知线性规划问题,如下: max z=x1+x2-x3 -x1+2x2+x3<=2 st. -2x1+x2-x3<=3 x1,x2,x3>=0 据对偶理论分析此问题有解的情况(最优,无界或无解)三、已知线性规划问题 max z=x1+4x2+x3+2x4 x1+2x2 +x4<=8 x2 +2x4<=6 st. x2+x3+x4<=9 x1+x2+x3 <=6 x1,x2,x3,x4>=0 最优解为(0,2,4,2)据对偶理论找出其对偶问题最优解四、单纯形法解下列线性规划问题 max z=3x1+2x2

x1+2x2<=6 st. 2x1+x2<=8 -x1+x2<=1 x2<=2 x1,x2>=0 1)第一、二、四约束的影子价格为多少? 2)变量x1价值系数增加2,最优解是否变化? 五、运输问题单价表如下,确定总运费最小的调运方案 B1 B2 B3 B4 产量 A1 3 10 3 11 14 A2 2 8 1 9 8 A3 10 6 7 4 18 销量10 12 6 12 40 六、设备更新题:某设备收益r(万元),维修保养费w(万元) 更新费g(万元)与役龄t(年)关系如下: r(t)=10-1/2 t w(t)=1+5/4 t g(t)=1/2+4/5 t 考虑资金占用利率I ,试建立10年更新计划动态规划模型

汇编语言

武汉理工大学华夏学院课程设计报告书 课程名称:汇编语言课程设计 题目:在屏幕上显示变换的图形 系名:信息工程系 专业班级:软件工程1131 姓名: 学号: 102128131 指导教师:李捷 2015 年 1 月 9 日

课程设计任务书 学生姓名: 专业班级: 软件1131 指导教师: 李捷 工作单位: 信息工程系 设计题目:在显示器上显示对称图1、图2 初始条件: PC 机上实现课程设计 要求完成的主要任务: 主要任务:(在规定的时间内完成下列任务) 1. 按”Esc ”退出程序;能有2种图形显示,2种色彩方案(见上图) 2. 按“1 , 2” 黑白----------显示图形1,图形2 3. 按“3 , 4”色彩方案1---显示图形1,图形2(颜色自定) 4. 按“5 , 6”色彩方案2---显示图形1,图形2(颜色自定)+ 时间安排: 设计报告撰写格式要求:(按提供的设计报告统一格式撰写) 1、 题目:在显示器上显示有色彩变换的数字对称图 2、设计目的:在课程设计实验中,利用顺序结构、循环结构和主、子程序的调用,更进 一步的学习和掌握汇编语言课程设计。 2、设计内容:写出简要的程序功能描述、程序运行条件--所需工具软件、输入/输出描述等。 3、程序结构:① 主要的段定义说明; ② 用到的子程序(宏)的功能说明、调用关系说明、参数传送方式说明等; ③ 主要算法描述等(各模块功能实现及典型指令的应用)。 4、设计步骤(注明时间安排) 5、程序流程图、源程序(程序必须有简单注释,源程序若太长,可作为附录) 6、实验结果(输出) 7、其他值得说明的内容(1)程序结构设计特点;(2)设计、调试程序心得、体会或不足。 附录:①源程序代码(必须有简单注释) ②参考文献 指 导 教 师 签 字: 2015年 1 月1日 系 主 任 签 字: 年 月 日

运筹学基础课后习题答案

运筹学基础课后习题答案 [2002年版新教材] 第一章导论 P5 1.、区别决策中的定性分析和定量分析,试举例。 定性——经验或单凭个人的判断就可解决时,定性方法 定量——对需要解决的问题没有经验时;或者是如此重要而复杂,以致需要全面分析(如果涉及到大量的金钱或复杂的变量组)时,或者发生的问题可能是重复的和简单的,用计量过程可以节约企业的领导时间时,对这类情况就要使用这种方法。 举例:免了吧。。。 2、. 构成运筹学的科学方法论的六个步骤是哪些? .观察待决策问题所处的环境; .分析和定义待决策的问题; .拟定模型; .选择输入资料; .提出解并验证它的合理性(注意敏感度试验); .实施最优解; 3、.运筹学定义: 利用计划方法和有关许多学科的要求,把复杂功能关系表示成数学模型,其目的是通过定量分析为决策和揭露新问题提供数量根据 第二章作业预测P25 1、. 为了对商品的价格作出较正确的预测,为什么必须做到定量与定性预测的结合?即使在定量预测法诸如加权移动平均数法、指数平滑预测法中,关于权数以及平滑系数的确定,是否也带有定性的成分? 答:(1)定量预测常常为决策提供了坚实的基础,使决策者能够做到心中有数。但单靠定量预测有时会导致偏差,因为市场千变万化,影响价格的因素很多,有些因素难以预料。调查研究也会有相对局限性,原始数据不一定充分,所用的模型也往往过于简化,所以还需要定性预测,在缺少数据或社会经济环境发生剧烈变化时,就只能用定性预测了。(2)加权移动平均数法中权数的确定有定性的成分;指数平滑预测中的平滑系数的确定有定性的成分。 2.、某地区积累了5 个年度的大米销售量的实际值(见下表),试用指数平滑法,取平滑系数α= 0.9,预测第6年度的大米销售量(第一个年度的预测值,根据专家估计为4181.9千公斤) 年度 1 2 3 4 5 大米销售量实际值 (千公斤)5202 5079 3937 4453 3979 。 答: F6=a*x5+a(1-a)*x4+a(1-a)~2*x3+a(1-a)~3*x2+a(1-a)~4*F1 F6=0.9*3979+0.9*0.1*4453+0.9*0.01*3937+0.9*0.001*5079+0.9*0.0001*4181.9

80X86汇编语言程序设计教程+课后习题答案(清华大学版)

第二章答案 Tarzan 版 题2.1 8086/8088通用寄存器的通用性表现在何处?8个通用寄存器各自有何专门用途?哪些 寄存器可作为存储器寻址方式的指针寄存器? 答:8086/8088通用寄存器的通用性表现在: 这些寄存器除了各自规定的专门用途外,他们均可以用于传送和暂存数据,可以保存 算术逻辑运算中的操作数和运算结果; 8个通用寄存器的专门用途如下: AX 字乘法,字除法,字I/O BX 存储器指针 CX 串操作或循环控制中的计数器 DX 字乘法,字除法,间接I/O SI 存储器指针(串操作中的源指针) DI 存储器指针(串操作中的目的指针) BP 存储器指针(存取堆栈的指针) SP 堆栈指针 其中BX,SI,DI,BP可作为存储器寻址方式的指针寄存器 题2.2 从程序员的角度看,8086/8088有多少个可访问的16位寄存器?有多少个可访问的8位 寄存器? 答:从程序员的角度看,8086/8088有14个可访问的16位寄存器;有8个可访问的8位寄存器; 题2.3 寄存器AX与寄存器AH和AL的关系如何?请写出如下程序片段中每条指令执行后寄存器 AX的内容: MOV AX,1234H MOV AL,98H MOV AH,76H ADD AL,81H SUB AL,35H

ADD AL,AH ADC AH,AL ADD AX,0D2H SUB AX,0FFH 答: MOV AX,1234H AX=1234H MOV AL,98H AX=1298H MOV AH,76H AX=7698H ADD AL,81H AX=7619H SUB AL,35H AX=76E4H ADD AL,AH AX=765AH ADC AH,AL AX=D15AH ADD AX,0D2H AX=D22CH SUB AX,0FFH AX=D12DH 题2.4 8086/8088标志寄存器中定义了哪些标志?这些标志可分为哪两类?如何改变这些标志 的状态? 答: 8086/8088标志寄存器中定义了9个标志,如下: CF: Carry Flag ZF: Zero Flag SF: Sign Flag OF: Overflow Flag PF: Parity Flag AF: Auxiliary Carry Flag DF: Direction Flag IF: Interrupt-enable Flag TF: Trap Flag 这些标志可分为两类,分别为: 1、运算结果标志; 2、状态控制标志; 采用指令SAHF可把AH中的指定位送至标志寄存器低8位SF、ZF、AF、PF、CF; 采用CLC可清除CF,置CF到0 采用STC可置CF到1 采用CLD可置DF到0 采用sTD可置DF到1

2015年清华大学826运筹学与统计学

2015年清华大学826运筹学与统计学(数学规划、应用随机模型、统计学各占1/3)考研复习参考书 科目:826 运筹学与统计学(数学规划、应用随机模型、统计学各占1/3)参考书:《运筹学(数学规划)(第3版)清华大学出版社,2004年1月 W.L.Winston 《运筹学》(应用随机模型)清华大学出版社,2004年2月 V.G. Kulkarni 《概率论与数理统计》(第1~9章)高等教育出版社,2001年盛聚等 考研复习方法,这里不详细展开。简单归纳为: 新祥旭考研提醒:首先,清楚考试明细,掌握真题,真题为本。通过真题,了解和熟知:考什么、怎么考、考了什么、没考什么;通过练习真题,了解:目前我的能力、复习过程中我的进步、我的考试目标。提醒一句:千万不要浪费大量时间做不相关的模拟题;千万不要把考研复习等同于做题目,搞题海战术。 其次,把握参考书,参考书为锚。弄懂、弄熟。考研复习如何才能成功?借用《卖油翁》里的一句话,那就是:手熟而已。明确考试之后,考研就基本上是一个熟悉吃透的过程。无论何时,参考书第一,不能轻视。所以,千万不要本末倒置,把做题凌驾于看书之上。如何才叫熟悉?我认为,要打破“讲速度,不讲效率”的做法,看了多少遍并不是检验熟悉与否的指标,合上书本,随时自我检测,能否心中有数、一问便知,这才是关键。 再次,制定计划,合理分配时间。不是每一本参考书都很重要,都一样重要,所以,在了解真题的基础上,要了解每一本书占多少分,如何命题考试,在此基础上,每一本参考书的主次轻重、复习方略也就清楚了,复习才不会像开摊卖药,平均用力。一个月制定一份计划书,每天写一句话鼓励自己,一个月调整一次复习重点,这都是必要的。 最后,快乐复习。考研复习是以什么样状态进行的,根源在于能否克服不良情绪。第一,报考对外汉语,你是因为喜欢这个专业吗?如果是,那么,就继续给自己这种暗示,那么你一定会发现,复习再紧张,也是愉悦的,因为你是为了兴趣而考研的;第二,规律的作息,不大时间战,消耗战,养精蓄锐。运动加休息,如果能每天都很规律,那么成功也就有了保障,负面情绪少了,效率也就高了。 总结为几个关键词,就是:知己知彼、本末分明。

运筹学教程清华第三版课后答案(第一章,第五章部分)

1.某饲养场饲养动物出售,设每头动物每天至少需700g蛋白质、30g矿物质、100mg 维生素。现有五种饲料可供选用,各种饲料每kg营养成分含量及单价如表1所示。表1 要求确定既满足动物生长的营养需要,又使费用最省的选用饲料的方案。 x表示满足动物生长的营养需要时,解:设总费用为Z。i=1,2,3,4,5代表5种饲料。 i 第i种饲料所需的数量。则有: 2.某医院护士值班班次、每班工作时间及各班所需护士数如表2所示。每班护士值班 开始时间向病房报道,试决定: (1)若护士上班后连续工作8h,该医院最少需要多少名护士,以满足轮班需要; (2)若除22:00上班的护士连续工作8h外(取消第6班),其他班次护士由医院排定上1~4班的其中两个班,则该医院又需要多少名护士满足轮班需要。表2 x第i班开始上班的人数,i=1,2,3,4,5,6 解:(1)设 i x第i 解:(2)在题设情况下,可知第五班一定要30个人才能满足轮班需要。则设设 i 班开始上班的人数,i=1,2,3,4。

a 3.要在长度为l的一根圆钢上截取不同长度的零件毛坯,毛坯长度有n种,分别为 j (j=1,2,…n)。问每种毛坯应当截取多少根,才能使圆钢残料最少,试建立本问题的数学模型。 解:设 x表示各种毛坯的数量,i=1,2,…n。 i 4.一艘货轮分前、中、后三个舱位,它们的与最大允许载重量如表3.1所示。现有三 种货物待运,已知有相关数据列于表3.2。 表3.1 表3.2 又为了航海安全,前、中、后舱实际载重量大体保持各舱最大允许载重量的比例关系。具体要求:前、后舱分别与中舱之间载重量比例的偏差不超过15%,前、后舱之间不超过10%。问该货轮应该载A,B,C各多少件运费收入才最大?试建立这个问题的线性规划模型。 x表示第i件商品在舱j的装载量,i,j=1,2,3 解:设 ij 1)商品的数量约束: 2)商品的容积约束: 3)最大载重量约束: 4)重量比例偏差的约束: 5.篮球队需要选择5名队员组成出场阵容参加比赛。8名队员的身高及擅长位置见表 5. 表5

运筹学(胡运权)第五版课后答案-运筹作业

运筹学(胡运权)第五版课后答案-运筹作业

47页1.1b 用图解法找不到满足所有约束条件的公共范围,所以该问题无可行解47页1.1d 无界解 1 2 3 4 5 4 3 2 1 - 1 -6 -5 -4 -3 -2 X2 X1 2x1- -2x1+3x 1 2 3 4 4 3 2 1 X1 2x1+x2=2 3x1+4x2= X

1.2(b) 约束方程的系数矩阵A= 1 2 3 4 2 1 1 2 P1 P2 P3 P4 基 基解 是否可行解目标函数值X1 X2 X3 X4 P1 P2 -4 11/2 0 0 否 P1 P3 2/5 0 11/5 0 是43/5 P1 P4 -1/3 0 0 11/6 否 P2 P3 0 1/2 2 0 是 5 P2 P4 0 -1/2 0 2 否 P3 P4 0 0 1 1 是 5 最优解A=(0 1/2 2 0)T和(0 0 1 1)T 49页13题 设Xij为第i月租j个月的面积 minz=2800x11+2800x21+2800x31+2800x41+4500x12+4500x22+4500x32+6000x1 3 +6000x23+7300x14 s.t. x11+x12+x13+x14≥15 x12+x13+x14+x21+x22+x23≥10 x13+x14+x22+x23+x31+x32≥20 x14+x23+x32+x41≥12 Xij≥0 用excel求解为: ( )

用LINDO求解: LP OPTIMUM FOUND AT STEP 3 OBJECTIVE FUNCTION V ALUE

汇编语言(沈美明,温冬婵)课后答案

汇编语言程序设计(第二版) (清华大学IBM-PC 汇编语言程序设计(第二版)沈美明温冬婵编著) 第二章 1、答:直接由指令指定的I/O端口数为256个。 2、答: 3、答:字节单元:(30022H)= AB H,(30024H)= EF H 字单元:(30021H)= AB34 H,(30022H)= CDAB H。 4、答:3017:000A的存储单元的物理地址是3017AH, 3015:002A的存储单元的物理地址是3017AH, 3010:007A的存储单元的物理地址是3017AH。 5、答:该程序的第一个字的物理地址是0AAA40H。 6、答:条件标志OF、SF、ZF、CF的值依次分别为0、0、0、0。 7、答:(1)AX、BX、CX、DX、AH、AL、BH、BL、CH、CL、DH、DL、 SP、BP、DI、SI(注意:学生尽量不要用SP参与加减运算) (2)CX (3)DX、AX、AH、AL (4)CS、DS、ES、SS (5)FLAGS (6)IP (7)SS、SP、BP 8、答:可以用来指示存储器地址的寄存器有BX、SP、BP、DI、SI、IP、CS、DS、 ES、SS。 9、答:唯一正确的是D。 第三章 2、答: (1)ADD DX, BX (2)ADD AL, [BX][SI] (3)ADD [BX+0B2H], CX (4)ADD [0524H], 2A59H (5)ADD AL, 0B5H 3、答: (1)MOV BX, OFFSET BLOCK + 0AH MOV DX, [BX] (2)MOV BX, 0AH MOV DX, BLOCK[BX] (3)MOV BX, OFFSET BLOCK MOV SI, 0AH MOV DX, [BX][SI]

清华大学杨顶辉数值分析第6次作业

清华大学杨顶辉数值分析第6次作业

9.令*()(21),[0,1]n n T x T x x =-∈,试证*{()}n T x 是在[0,1]上带权 2 ()x x x ρ= -****0123(),(),(),()T x T x T x T x . 证明: 1 1 **2 1 1 * *20 12 2 1**20 ()()()(21)(21)211()()()()()211()22 ()()1()1()()()()()1n m n m n m n m n m n n m n m x T x T x dx x T x dx x x t x x T x T x dx t T t dt t t t T t dt t T x x x T x T x dx t T t t ρρρ---=---=-=++-= --= -???? ?令,则 由切比雪夫多项式1 01=02 m n dt m n m n ππ ≠??? =≠??==??? 所以*{()}n T x 是在[0,1]上带权2 ()x x x ρ= - *00*11* 2 2 2 2*33233()(21)1()(21)21 ()(21)2(21)188()(21)4(21)3(21)3248181 T x T x T x T x x T x T x x x x T x T x x x x x x =-==-=-=-=--=-=-=---=-+- 14.已知实验数据如下: i x 19 25 31 38 44 i y 19.0 32.3 49.0 73.3 97.8 用最小二乘法求形如2y a bx =+的经验公式,并求均方误差 解: 法方程为

清华_第三版_运筹学教程_课后答案~(_第一章_第五章部分)

清华第三版 运筹学 答案[键入文字] [键入文字] [键入文字] 运筹学教程 1. 某饲养场饲养动物出售,设每头动物每天至少需700g 蛋白质、30g 矿物质、100mg 维生素。现有五种饲料可供选用,各种饲料每kg 营养成分含量及单价如表1所示。 表1 要求确定既满足动物生长的营养需要,又使费用最省的选用饲料的方案。 解:设总费用为Z 。i=1,2,3,4,5代表5种饲料。i x 表示满足动物生长的营养需要时,第i 种饲料所需的数量。则有: ????? ? ?=≥≥++++≥++++≥++++++++=5,4,3,2,1,01008.022.05.0305.022.05.07008623..8.03.04.07.02.0min 54321543215432154321i x x x x x x x x x x x x x x x x t s x x x x x Z i 2. 某医院护士值班班次、每班工作时间及各班所需护士数如表2所示。每班护士值班 开始时间向病房报道,试决定: (1) 若护士上班后连续工作8h ,该医院最少需要多少名护士,以满足轮班需要; (2) 若除22:00上班的护士连续工作8h 外(取消第6班),其他班次护士由医院 排定上1~4班的其中两个班,则该医院又需要多少名护士满足轮班需要。 表2

6 2:00~6:00 30 解:(1)设x 第i 班开始上班的人数,i=1,2,3,4,5,6 ???????????=≥≥+≥+≥+≥+≥+≥++++++=且为整数 6,5,4,3,2,1,030 2050607060..min 655443 322161 654321i x x x x x x x x x x x x x t s x x x x x x Z i 解:(2)在题设情况下,可知第五班一定要30个人才能满足轮班需要。则设设i x 第i 班开始上班的人数,i=1,2,3,4。 ??? ????? ?? ??? ??=≥=+++=≥+++=+++=≥+++=+++=≥+++=+++=≥+++++++=4 ,3,2,1,1002 1502 16021702 ,160..30 min i 444342414444433422411434 33323133 443333223113242322212244233222211214131211114413312211114321j i y x y y y y y x y x y x y x y y y y y y x y x y x y x y y y y y y x y x y x y x y y y y y y x y x y x y x y t s x x x x Z ij 变量,—是,,,第四班约束,,第三班约束,,第二班约束,第一班约束 3. 要在长度为l 的一根圆钢上截取不同长度的零件毛坯,毛坯长度有n 种,分别为j a (j=1,2,…n )。问每种毛坯应当截取多少根,才能使圆钢残料最少,试建立本问题的数学模型。 解:设i x 表示各种毛坯的数量,i=1,2,…n 。

《汇编语言》学习笔记(清华大学 王爽)

清华大学《汇编语言》(王爽)读书笔记 第一章基础知识 ◎汇编语言由3类指令组成 汇编指令:机器码的助记符,有对应机器码。 伪指令:没有对应机器码,由编译器执行,计算机并不执行 其他符号:如+-*/,由编译器识别,没有对应机器码 ◎一个CPU有n根地址线,则可以所这个CPU的地址线宽度为n,这样的CPU最多可以寻找2的n 次方个内存单元。 ◎ 1K=2^10B 1M=2^20B 1G=2^30B ◎8086 CPU地址总线宽度为20,寻址范围为00000~FFFFF 00000~9FFFF 主存储器地址空间(RAM) A0000~BFFFF 显存地址空间 C0000~FFFFF 各类ROM地址空间 第二章寄存器(CPU工作原理) ◎16位结构描述了一个CPU具有下面几个方面的结构特性 运算器一次最多可以处理16位的数据 寄存器的最大宽度为16位 寄存器和运算器之间的通路为16位 ◎8086有20位地址总线,可以传送20位地址,达到1M的寻址能力。采用在内部用两个16位地址合成的方法来形成一个20位的物理地址 ◎物理地址 = 段地址 × 16 + 偏移地址 ◎在编程是可以根据需要,将若干地址连续的内存单元看作一个段,用段地址×16定位段的起始地址(基础地址),用偏移地址定位段中的内存单元。段地址×16必然是16的倍数,所以一个段的起始地址也一定是16的倍数;偏移地址位16位,16位地址的寻址能力为64KB,所以一个段的长度最大为64KB ◎8086有四个段寄存器 CS、DS、SS、ES ◎CS为代码段寄存器,IP为指令指针寄存器。任意时刻,设CS中内容为M、IP中内容为N,8086CPU从内存M×16+N读取一条指令执行 ◎不能用mov修改CS、IP,因为8086CPU没有提供这样功能,可用指令JMP 段地址:偏移地址。JMP 2AE3:3 JMP AX 修改IP 第三章寄存器(内存访问) ◎DS数据段寄存器。不能将数据直接送入段寄存器,所以『MOV DS, 1』不正确 ◎字在存储时要两个连续的内存单元,低位在低地址,高位在高地址 ◎[address]表示一个偏移地址为address的内存单元 ◎SS:SP指向栈顶元素 ◎PUSH AX:(1)SP = SP - 2;(2)AX送入SS:SP ◎POP AX:(1)SS:SP送入AX;(2)SP = SP + 2 ◎PUSH/POP 寄存器 PUSH/POP 段寄存器 PUSH/POP 内存单元 第四章第1个程序 ◎可执行文件包含两部分:程序和数据,相关的描述信息 ◎程序加载后, ds中存放这程序所在内存区的段地址,这个内存区的偏移地址为0,策程序所在的内存区的地址为ds:0;这个内存区的前256个字节中存放的是PSP,dos用来和程序进行通信。从256字节处向后的空间存放的是程序。 第五章 [BX]和loop指令 ◎[BX]表示一个内存单元,它的段地址在ds中,偏移地址在bx中。MOV AX,[BX] MOV AL,[BX]

运筹学教程 清华 第三版 课后答案( 第一章,第五章部分)

1. 某饲养场饲养动物出售,设每头动物每天至少需700g 蛋白质、30g 矿物质、100mg 维生素。现有五种饲料可供选用,各种饲料每kg 营养成分含量及单价如表1所示。 表1 要求确定既满足动物生长的营养需要,又使费用最省的选用饲料的方案。 解:设总费用为Z 。i=1,2,3,4,5代表5种饲料。i x 表示满足动物生长的营养需要时,第i 种饲料所需的数量。则有: ????? ? ?=≥≥++++≥++++≥++++++++=5,4,3,2,1,01008.022.05.0305.022.05.07008623..8.03.04.07.02.0min 54321543215432154321i x x x x x x x x x x x x x x x x t s x x x x x Z i 2. 某医院护士值班班次、每班工作时间及各班所需护士数如表2所示。每班护士值班 开始时间向病房报道,试决定: (1) 若护士上班后连续工作8h ,该医院最少需要多少名护士,以满足轮班需要; (2) 若除22:00上班的护士连续工作8h 外(取消第6班),其他班次护士由医院 排定上1~4班的其中两个班,则该医院又需要多少名护士满足轮班需要。 表2

解:(1)设x 第i 班开始上班的人数,i=1,2,3,4,5,6 ???????????=≥≥+≥+≥+≥+≥+≥++++++=且为整数 6,5,4,3,2,1,030 2050607060..min 655443 322161 654321i x x x x x x x x x x x x x t s x x x x x x Z i 解:(2)在题设情况下,可知第五班一定要30个人才能满足轮班需要。则设设i x 第i 班开始上班的人数,i=1,2,3,4。 ??? ????? ?? ??? ??=≥=+++=≥+++=+++=≥+++=+++=≥+++=+++=≥+++++++=4 ,3,2,1,1002 1502 16021702 ,160..30 min i 444342414444433422411434 33323133 443333223113242322212244233222211214131211114413312211114321j i y x y y y y y x y x y x y x y y y y y y x y x y x y x y y y y y y x y x y x y x y y y y y y x y x y x y x y t s x x x x Z ij 变量,—是,,,第四班约束,,第三班约束,,第二班约束,第一班约束 3. 要在长度为l 的一根圆钢上截取不同长度的零件毛坯,毛坯长度有n 种,分别为j a (j=1,2,…n )。问每种毛坯应当截取多少根,才能使圆钢残料最少,试建立本问题的数学模型。 解:设i x 表示各种毛坯的数量,i=1,2,…n 。 ?????≤= ∑∑==是整数i 1 1 1max x x a x a Z i i n i i i n i

清华大学杨顶辉数值分析第6次作业

9.令*()(21),[0,1]n n T x T x x =-∈,试证*{()}n T x 是在[0,1] 上带权()x ρ=的正交多项式,并求****0123(),(),(),()T x T x T x T x . 证明: 1 1 * *0 1 1 * *011**0 ()()()(21)(21)211()()()()()2()()()()()()()()n m n m n m n m n m n n m n m x T x T x dx x T x dx t x x T x T x dx t T t dt t T t dt T x x T x T x dx t T t ρρρ---=--=-== = ???? ?令,则 由切比雪夫多项式1 01=02 m n dt m n m n ππ ≠??? =≠??==??? 所以*{()}n T x 是在[0,1] 上带权()x ρ= *00*11* 22 2 2*33233()(21)1()(21)21 ()(21)2(21)188()(21)4(21)3(21)3248181 T x T x T x T x x T x T x x x x T x T x x x x x x =-==-=-=-=--=-=-=---=-+- 14.已知实验数据如下: 用最小二乘法求形如2y a bx =+的经验公式,并求均方误差 解: 法方程为

22222(1,)(1,1)(1,)(,)(,1)(,)a y x b x y x x x ?????? =???? ?????? ?? 即 5 5327271.453277277699369321.5a b ??????=???????????? 解得 0.972579 0.050035a b =?? =? 拟合公式为20.9725790.050035y x =+ 均方误差 2 4 2 2 0[]0.015023i i i y a bx σ==--=∑ 21.给出()ln f x x =的函数表如下: 用拉格朗日插值求ln 0.54的近似值并估计误差(计算取1n =及2n =) 解:1n =时,取010.5,0.6x x == 由拉格朗日插值定理有 1 100.60.5 0.693147 0.510826 0.50.(60.60.51.82321)0 1.()6047()52 j j j x x x L x f x l x ==------=-=∑ 所以1ln0.54(0.54)0.620219L ≈=- 误差为ln 0.54(0.620219)= 0.004032ε=-- 2n =时,取0120.4,0.5,0.6x x x === 由拉格朗日插值定理有

相关文档
相关文档 最新文档