汇编冒泡排序,数组题

数组题
  • cx应为长度-1
  • 二层循环要保存cx,si

把数组中的0去掉,其他往前移动,最后面补0

DATAS SEGMENT
    ;此处输入数据段代码  
    ar db 6,33H,30H,30H,33H,30H,33H,'$'
DATAS ENDS

STACKS SEGMENT
    ;此处输入堆栈段代码
STACKS ENDS

CODES SEGMENT
    ASSUME CS:CODES,DS:DATAS,SS:STACKS
START:
    MOV AX,DATAS
    MOV DS,AX
    mov si,1
    mov cl,ar
    dec cl
L1:
   

    PUSH SI
    push cx
L2:
    mov bl,ar[si]
    cmp bl,30H
    jnz l3 ;不是0
    xchg bl,ar[si+1]
    mov ar[si],bl
L3:
    inc si
    LOOP l2
    pop cx
    POP SI

    
    loop L1


    lea dx,ar+1
    mov ah,9
    int 21H
    ;此处输入代码段代码
    MOV AH,4CH
    INT 21H
CODES ENDS
    END START

冒泡排序

DATAS SEGMENT
    ;此处输入数据段代码  
    array1 db 'h','a','d','c','t','b','y','l','$'
DATAS ENDS

STACKS SEGMENT
    ;此处输入堆栈段代码
STACKS ENDS

CODES SEGMENT
    ASSUME CS:CODES,DS:DATAS,SS:STACKS
START:
    MOV AX,DATAS
    MOV DS,AX
    ;此处输入代码段代码
    
    mov cx,7
    lea bx,array1
    mov si,0
L1:
  ;每一轮由开始比较,最大的沉到最后面
    push si
    push cx
L2:   
    mov al,array1[si]
    cmp al,array1[si+1]
    jb L3           ;小于
    xchg al,array1[si+1] 
    mov array1[si],al

L3: 
    inc si
    LOOP L2
    pop cx
    pop si
    LOOP L1


    lea dx,array1
    mov ah,09h
    int 21H
    
    MOV AH,4CH
    INT 21H
CODES ENDS
    END START
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值