汇编-冒泡排序

冒泡排序程序实现:使数组的数从大到小的顺序排序

data segment
	a	dw	20 dup(?)		;20个数据比较
data ends

code segment
	assume cs:code, ds:data
main proc far

start:
	;set up stack for return		;保留现场,数据入栈
	push	ds
	sub	ax, ax
	push	ax							;??

	mov	ax, data
	mov	ds, ax

;program started--------------------------------------------------

	mov	cx, 20		;n个数据需要比较的最大次数=n(n+1)/2
	dec	cx

loop1:					
	*mov	di, cx*
	mov	bx, 0
	mov cx,19
*loop2:
	mov	ax, a[bx]
	cmp	ax, a[bx+2]
	jge	continue
	xchg	ax, a[bx+2]
	mov	a[bx], ax

continue:
	add	bx, 2
	loop	loop2*
	*mov	cx, di*
	loop	loop1

	ret
main endp

code ends
	end start
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值