查看: 26|回复: 0

[教程] 汇编程序成绩排序的实现

[复制链接]

2

主题

0

回帖

0

积分

热心网友

金币
0
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2009-8-13
发表于 2020-2-9 15:42:36 | 显示全部楼层 |阅读模式

汇编程序 成绩排序的实现

【任务】
  在数据区,给出了学生人数及汇编语言课程的成绩,请将成绩排序并保存在原数据区。
  下面给出部分代码,要求完成排序子程序。
  程序中给出的数据段,包括20位同学的成绩,每名同学的数据占1字节。

参考程序段:

assume cs:cseg, ds:dseg, ss:sseg
sseg segment stack
  dw 100H dup (?)
sseg ends
dseg segment
  db 20
  db 98,61,57,82,89,73,61,58,53,54
  db 84,78,70,64,84,63,76,84,83,86
dseg ends
cseg segment
 start: mov ax, dseg
     mov ds, ax
     mov cl, ds:[0]
     mov ch, 0   ;cx中存储要排序数的个数
     mov bx, 1   ;要排序数的起始偏移地址
     call sort

     mov ax, 4c00h
     int  21h
;子程序名:sort
;功  能:对从(DS):(bx)开始的(cx)个字节排序
;入口参数:(DS):(BX)保存数据的起始地址
;    (cx)中是要排序的数据个数
;出口参数:无
sort proc
   ;这儿写子程序
sort endp

cseg ends
end start

【参考解答】

assume cs:cseg, ds:dseg, ss:sseg
sseg segment stack
  dw 100H dup (?)
sseg ends
dseg segment
  db 20
  db 98,61,57,82,89,73,61,58,53,54
  db 84,78,70,64,84,63,76,84,83,86
dseg ends
cseg segment
 start: mov ax, dseg
     mov ds, ax
     mov cl, ds:[0]
   mov ch, 0   ;cx中存储要排序数的个数
   mov bx, 1   ;要排序数的起始偏移地址
   call sort

     mov ax, 4c00h
     int  21h

sort proc
     push si
     push ax
     dec cx   ;外层循环次数为数据个数减1
 c1:        ;排序的外层循环
     push cx   
     mov si, bx
 c2:        ;排序的内层循环
     mov al, [si]
     cmp al, [si+1]
     jbe noswap
     mov ah, [si+1]
   mov [si+1], al 
     mov [si], ah 
 noswap: inc si 
     loop c2 
     pop cx
     loop c1

   pop ax
   pop si
   ret
sort endp

cseg ends
end start

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持琼殿技术社区。

您可能感兴趣的文章:
  • 汇编实现直接插入排序的方法示例
  • 汇编实现简单选择排序的方法示例
  • 汇编实现冒泡排序的方法示例
  • 汇编语言 输入10个数排序并输出的实现
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部