汇编程序成绩排序的实现

汇编程序 成绩排序的实现

【任务】
  在数据区,给出了学生人数及汇编语言课程的成绩,请将成绩排序并保存在原数据区。
  下面给出部分代码,要求完成排序子程序。
  程序中给出的数据段,包括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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 汇编语言 输入10个数排序并输出的实现

    一:题目描述 在键盘输入任意10个数 按从小到大排序后,在计算机屏幕上先输出来.要有结果提示(字符串显示). 将10个数做累加,结果在计算机屏幕显示累加和. 二:伪指令的定义 1.数据段 ATAS SEGMENT string_1 DB 'Please input a numbers(0-65536):','$' string_2 DB 'ERROR: OVERFLOW! Please input again:','$' string_3 DB 'The array you have input

  • 汇编实现简单选择排序的方法示例

    上阵子重温数据结构,差不多更新到排序.这学期学了汇编语言,其中有几个实验便是实现内部排序算法.以下是实现简单选择排序的程序设计: S0 SEGMENT STACK DW 20 DUP(?) TOP LABEL WORD S0 ENDS S1 SEGMENT TIP DB "Input ten number and separate the numbers with space:", 0DH, 0AH, 24H ARY DW 20 DUP(0) CRLF DB 0DH, 0AH, 24H

  • 汇编实现直接插入排序的方法示例

    上一篇实现了简单插入排序的算法,这一篇主要实现直接插入排序算法: S0 SEGMENT STACK DW 20 DUP(?) TOP LABEL WORD S0 ENDS S1 SEGMENT TIP DB "Input ten number and separate the numbers with space:", 0DH, 0AH, 24H ARY DW 20 DUP(0) CRLF DB 0DH, 0AH, 24H N DW 0 E DW 0 S1 ENDS S2 SEGMEN

  • 汇编实现冒泡排序的方法示例

    冒泡排序算法的运作如下:(从后往前) 1.比较相邻的元素.如果第一个比第二个大,就交换他们两个. 2.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应该会是最大的数. 3.针对所有的元素重复以上的步骤,除了最后一个. 4.持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较. 以下为实现代码: S0 SEGMENT STACK DW 30 DUP(?) TOP LABEL WORD S0 ENDS S1 SEGMENT TIP DB "Input

  • 汇编程序成绩排序的实现

    汇编程序 成绩排序的实现 [任务] 在数据区,给出了学生人数及汇编语言课程的成绩,请将成绩排序并保存在原数据区. 下面给出部分代码,要求完成排序子程序. 程序中给出的数据段,包括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

  • 通过c++的sort函数实现成绩排序功能

    sort函数用于C++中,对给定区间所有元素进行排序,默认为升序,也可进行降序排序.sort函数进行排序的时间复杂度为n*log2n,比冒泡之类的排序算法效率要高,sort函数包含在头文件为#include<algorithm>的c++标准库中. 题目描述: 有N个学生的数据,将学生数据按成绩高低排序,如果成绩相同则按姓名字符的字母排序,如果姓名的字母序也相同,则按照学生的年龄排序,并输出N个学生排序后的信息. #include<stdio.h> #include<algor

  • Python 处理表格进行成绩排序的操作代码

    一.需求分析 我们首先有一个成绩表单,但是学生的成绩是按照学号进行排序的,现在,我们希望清晰明了的知道每一个学生的名次,并且需要将学生按照成绩的高低重新进行排序. 也就是说,我们将学生从按照学号排序转变为按照成绩从高到低进行排序. 二.代码呈现 这个需求其实比较简单,于是,我们直接呈现代码,主要问题是Excel表格的读写操作,这个解决以后就十分简单了. Excel读:xlrd模块 Excel写:xlwt模块 代码以及解释如下: import xlwt import xlrd # 导入模块 wb

  • Java案例使用比较排序器comparator实现成绩排序

    需求:用TreeSet集合存储多个学生信息(姓名,语文成绩,数学成绩),并遍历该集合:要按照总分从高到低进行排序 分析: 1.创建学生类 成员变量 姓名,语文成绩.数学成绩:成员方法 求总分:构造方法 无参构造,带参构造: get\set方法 2.创建测试类 3.创建TreeSet集合对对象,并使用内部类的方式重写compare方法 要定好排序规则,主要条件按照总分从高到底排序,在总分相同的情况下按照语文成绩排序,在两者都相同的情况下判断姓名是否相同,相同就不存储,不相同存进来,按照姓名字母进行

  • Python实现学生成绩管理系统

    本文实例为大家分享了Python实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 基本功能: 输入并存储学生的信息:通过输入学生的学号.姓名.和分数,然后就可以把数据保存在建立的student文件里面. 打印学生的所有信息:通过一个打印函数就可以把所有的信息打印在屏幕上. 修改学生信息:这个功能首先通过查询功能查询出该学生是否存在,如果存在就对该学生的信息进行修改,如果不存在则返回到主界面. 删除学生信息:该功能是对相应的学生进行删除操作,如果学生存在就查找到进行删除. 按学生成绩进行排

  • C语言学生成绩管理系统小设计

    本文实例为大家分享了C语言学生成绩管理系统的具体代码,供大家参考,具体内容如下 一.本设计涉及的重要C语言知识有: 1.单链表的各种操作 2.文件流的操作 3.单链表的排序 二.本设计主要以下几个模块组成 1.学生成绩添加模块 2.学生成绩删除模块 3.学生成绩修改模块 4.学生成绩检索模块 5.学生成绩显示模块(包括成绩排序) 6.学生成绩保存模块 效果图: 本设计大概5.6百行代码左右,通过这个设计,本人感觉C语言熟练了很多, 希望能对像我一样的C语言菜鸟同学会有点帮助,废话少说,咱们上代码

  • 基于C语言实现学生成绩管理系统

    本文实例为大家分享了C语言实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 这里只贴代码,具体介绍省略. #include <stdio.h> #include <io.h> #include <conio.h> #include <stdlib.h> #include <string.h> #define MAX 200 struct student { char no[10]; // 学号 char name[50]; // 姓名 f

  • C语言实现简单学生成绩管理系统

    本文实例为大家分享了C语言实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 C语言小项目 实现一个学生成绩管理系统 系统功能: 1.实现所有学生成绩的录入(利用结构体数组),当输入字符为end时候,结束成绩的录入:  2.实现所有学生信息的输出  3.输入指定学生姓名,并能输出这名学生的信息  4.将学生成绩按照语文和数学成绩排序 思路: 1. 首先,先把这个小项目的框架打好.考虑要写几个文件,每一个文件里面实现怎样的功能.考虑到这个小项目的代码量以及程序的易读性,我决定将写三个文件.一

  • C语言实现学生成绩管理系统实战教学

    趁着放假无事,开始用C语言开发一些小的项目,巩固基础知识的同时学习新的知识. 学生成绩管理系统实现的功能有:成绩录入.学生成绩查询.删除.修改.通过文件保存等. 开发这样一个系统需要具备的知识:线性表(链表).文件操作.排序(如果需要成绩排序). 开发环境为VS2015:在Linux下没有conio.h的头文件,需要修改与getch()函数相关的代码. #include <stdio.h> #include <stdlib.h> #include <string.h>

  • python实现简单成绩录入系统

    学了一个多月的python,做了一个小程序:python实现简单成绩录入系统,实验一下 menu部分 from tkinter import*#这是一个python模块,python3中都有 import tkinter.messagebox#这也是一个模块 from file_read import read from file_write import write class student_main():#定义一个学生类 def __init__(self): self.name =''

随机推荐