汇编理论课第二次作业

本文介绍了使用汇编语言实现的两种求最大值的方法:一是从键盘输入10个整数并找出最大值;二是从预定义的两组整数数组中分别找出每组的最大值。通过具体的汇编代码示例展示了如何进行数值比较和存储最大值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第二次:1.求10个整数的最大值    2.求两个数组的最大值(用函数封装)

1.从键盘输入10个整数,并存放在内存中,求这10整数 最大值,并在屏幕中输出最大值

Include Irvine32.inc
.data
	arr dd 10 dup(?)
.code
main PROC
	mov ebx,0
input: 	
	cmp ebx,9
	ja final0
	call readint
	mov arr[4 * ebx],eax
	add ebx,1
	jmp input	;输入10个数
final0:
	mov ebx,0
	mov eax,arr[0]
again:	
	cmp ebx,9	;不用loop
	ja final
	cmp eax,arr[4 * ebx]
	ja next
	mov eax,arr[4 * ebx]
next:
	add ebx,1
	jmp again 
final:
	call writeint
	exit
main ENDP
END main 

2. 在内存存放有两组整数中,分别求两组整数最大值,并在屏幕中输出各自最大值

Include Irvine32.inc
.data
	arr1 dd 32,44,55,1,10,2,111
	arr2 dd 34,555,1,42,52,11,22,453
.code
main PROC
	mov edx,offset arr1	; arr1的首地址放到edx
	mov ecx,6		; ecx存len
	call max		; 用max封装函数
	call writeint
	call Crlf		; \n
	mov edx,offset arr2 
	mov ecx,7
	call max
	call writeint
	exit
main ENDP
max PROC
				;edx是首地址
				;ecx是长度
	mov eax,[edx]		;eax放max
	mov ebx,0		;ebx<-0
again:				;不使用loop
	cmp ebx,ecx
	ja final
	cmp eax,[edx + 4 * ebx]
	ja next
	mov eax,[edx + 4 * ebx]
next:
	add ebx,1
	jmp again
final:
	ret
max ENDP	
END main 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值