编写程序,将内部RAM30H-40H单元共32个有符号数最大者找出,存入50H单元。

编写程序,将内部RAM30H-40H单元共32个有符号数最大者找出,存入50H单元。,第1张

程序,其实,写得很罗嗦。

他是把正数和正数相减,判断一下大小;

负数负数相减,也判断一下大小。

其实,负数和负数相减后的判断,和正数相减的判断准则相同。

两个带负号的数,其形式是补码。

FFH,是-1,在负数中,它最大。

80H,是-128。它比 FF 小。

负数和负数相减后,CY=1,则说明,被减数较小。

减法程序,不用分开写两段。

另外,既然是求最大值,那么,开始时,在 RESULT 中,

应该先存放一个最小的数字,即-128。

他存放的是-1,这是错误的。

正确程序如下:

MAIN:

    MOV   RESULT, #80H  ;关键字,不应该是0FFH

    MOV   R0, #NUMBERS

    MOV   R5, #COUNT

NEXT:

    MOV   A, RESULT     ;取关键字

    JB    ACC7, RN     ;是负数则转移

    MOV   A, @R0

    JNB   ACC7, _SUB_  ;两个都是正数,转去相减

    JMP   NOEXCH        ;是负数则不用更换

RN:

    MOV   A, @R0

    JB    ACC7, _SUB_  ;两个都是负数,转去相减

    JMP   EXCH          ;是正数则更换

_SUB_:

    CLR   C

    MOV   A, RESULT

    SUBB  A, @R0        ;都是正数或都是负数,相减

    JNC   NOEXCH        ;够减就不更换

EXCH:

    MOV   RESULT, @R0

NOEXCH:

    INC   R0

    DJNZ  R5, NEXT

    SJMP  $

END

e=1+1/1!+1/2!+1/3!+

C代码:

#include<stdioh>

void main()

{

double e=1;

double jc=1;//求阶乘,并存入jc中

int i=1;

while(1/jc>=1e-6)

{

e=e+1/jc;

i++;

jc=jci;

}

printf("e=%f\n",e);

}

》其他参考答案》》:>

电脑出现的故障原因:

1、 *** 作系统文件损坏。

2、MBR表损坏。

3、硬盘数据线松了。

4、硬盘坏了。

解决方法:

1、重新安装 *** 作系统。参考系统下载基地安装教程>

你等我

DATANUM=10 ;设有10个数据

STACK SEGMENMT STACK ‘STACK’

DW 100H DUP()

TOP LABEL WORD

STACK ENDS

DATA SEGMENT

DATABUF DW DATANUM

DB DATANUM DUP(?)

DATA EDATANUMDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK

START:

MOV AX,DATA

MOV DS,AX

MOV ES,AX

MOV AX,STACK

MOV SS,AX

LEA SP,TOP

; 取出随机数据

MOV CX,DATABUF

LEA SI,DATABUF+2

MOV BL,23

MOV AL,11

LP:

MOV [SI],AL

INC SI

ADD AL,BL

LOOP LP

; 数据排序

MOV CX,DATABUF

DEC CX

LEA SI,DATABUF+2

ADD SI,CX

LP1:

PUSH CX

PUSH SI

LP2:

MOV AL,[SI]

CMP AL,[SI-1]

JAE NOXCHG

XCHG AL,[SI-1]

MOV [SI],AL

NOXCHG:

DEC SI

LOOP LP2

POP SI

POP CX

LOOP LP1

;数据排序结束

MOV AH,4CH ;返回DOS

MOV AL,0

IDATANUMT 21H

CODE ENDS

END START

我这个连中断都用上了

第二题

PUSH PSW ;保护现场

PUSH A

CLR C ;进位标志位清零

MOV DATA,DATA2

MOV A,DATA1

SUBB A,DATA ;求Yn-1 -Yn

JNC COMPARE ;如果Yn-1 -Yn≥0,转COMPARE

CPL A ;如果Yn-1 -Yn<0, 求补

INC A

COMPARE: CLR C

SUBB A,LIMIT ;│Yn-Yn-1│和△y比较

JC OVER ;如果│Yn-Yn-1│≤△y,DATA2→DATA

MOV DATA,DATA1 ;如果│Yn-Yn-1│>△y,DATA1→DATA

OVER: POP A ;恢复现场

POP PSW

RET ;返回

这个作为参考,是MCS的

;入口 :A,SDAT,DELTY

;占用资源:B

;堆栈需求:2字节

;出口 :A

JUGFILT :MOV B,A

CLR C

SUBB A,SDAT

JNC JUGFT1

CPL A

INC A

JUGFT1 :SETB A

SUBB A,#DELTY

JNC JUGFT3

MOV A,SDAT

RET

JUGFT3 :MOV A,B

MOV SDAT,A

RET

;中位值滤波程序

;入口 :ADDPH,ADDPL,N

;占用资源:ESELSORT

;堆栈需求:4字节

;出口 :A

MEDFILT :LCALL ESELSORT

MOV A,N

CLR C

RRC A

ADD A,ADDPL

MOV DPL,A

MOV A,ADDPH

MOV DPH,A

JNC MEDFT1

INC DPH

MEDFT1 :MOVX A,@DPTR

RET

;N点算术平均滤波

;入口 :ADDPH,ADDPL,N

;占用资源:B,R3,R4

;堆栈需求:2字节

;出口 :A

AVFILT :MOV A,ADDPL

MOV DPL,A

MOV A,ADDPH

MOV DPH,A

CLR A

MOV R3,A

MOV R4,A

MOV R7,N

AVFT1 :MOVX A,@DPTR

INC DPTR

ADD A,R4

MOV R4,A

JNC AVFT2

INC R3

AVFT2 :DJNZ R7,AVFT1

MOV R7,N

MOV R2,#00H

LCALL NDIV31

MOV A,R4

RET

;N点加权平均滤波

;入口 :ADDPH,ADDPL,N

;占用资源:B,R3,R4

;堆栈需求:2字节

;出口 :A

QAVFILT :CLR A

MOV R3,A

MOV R4,A

MOV R7,N

MOV P2,ADDPH

MOV R1,ADDPL

MOV DPTR,#QAVTAB

QAVFT1 :MOVC A,@A+DPTR

MOV B,A

MOVX A,@R1

INC DPTR

INC R1

MUL AB

ADD A,R4

MOV R4,A

MOV A,B

ADDC A,R3

MOV R3,A

DJNZ R7,QAVFT1

MOV A,R4

JNB ACC7,QAVFT2

INC R3

QAVFT2 :MOV A,R3

RET

QAVTAB :DB

;一阶加权滞后滤波程序

;入口 :A,DELTY

;占用资源:B,R3,R4

;堆栈需求:2字节

;出口 :A

BQFILT :MOV B,A

CLR A

MOV DPTR,#ABTAB

MOVC A,A+DPTR

MUL AB

MOV R4,A

MOV R3,B

MOV A,01H

MOVC A,A+DPTR

MOV B,DELTY

MUL AB

ADD A,R4

MOV R4,A

MOV A,B

ADDC A,R3

MOV R3,A

MOV A,R4

JNB ACC7,FT1

INC R3

FT1 :MOV A,R3

MOV DELTY,A

RET

BQTAB :DB 80H,80H

以上就是关于编写程序,将内部RAM30H-40H单元共32个有符号数最大者找出,存入50H单元。全部的内容,包括:编写程序,将内部RAM30H-40H单元共32个有符号数最大者找出,存入50H单元。、编写程序,根据近似公式e≈1+1/(1!)+1/(2!)+1/(3!)+…+1/(n!)计算e的近似值、电脑开机出现 no bootable device is detected.system will enter the bios setup等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zz/9749771.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存