汇编:汇编语言实现冒泡排序(条件转移指令)

 1 ;===============================
 2 ;循环程序设计
 3 ;条件转移指令实现
 4 ;冒泡排序
 5 ;for(int i=0;i<N;i++){
 6 ;   for(int h=0;j<N-1-i>;j++){
 7 ;      if(array[j]>array[j+1]){
 8 ;           exchange(array[j],array[j+1]);
 9 ;        }
10 ;   }   
11 ;}
12 DATAS SEGMENT
13 N equ 16        ;待排序的个数
14 DATAS ends
15 CODES SEGMENT
16     ASSUME CS:CODES, DS:DATAS
17     START:
18         mov AX,8000H        ;待排序的内容的段地址
19         mov DS,AX          
20 
21         mov bx,-1
22         mov si,1            
23 
24     flag1:
25         mov di,0
26 
27     flag2:
28         mov al,[bx+di]
29         cmp al,[bx+di+1]
30         ja next1            ;大于
31         xchg al,[bx+di+1]   
32         mov  [bx+di],al     ;交换
33     next1:
34         inc di
35         xor cx,cx
36         mov cx,N-1
37         sub cx,si
38         cmp di,cx
39         jbe flag2
40 
41     next2:
42         inc si
43         cmp si,N-1
44         jbe flag1
45 
46     exit:
47         mov ah,4ch
48         int 21H
49 CODES ends
50     end START
51 ;===============================

 

转载于:https://www.cnblogs.com/roseAT/p/10249576.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值