汇编太难了(2)——输入n个数,排序输出

这篇博客介绍如何在汇编语言中输入N个数并排序,详细阐述了将输入的数字存储到数组并进行排序的过程,包括排序前后的数组元素展示。文章提供了代码示例,并指出尽管代码量较多,但每个步骤都有清晰说明,适合初学者理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

输入一个数N,然后依次输入N个数,每个数之间隔一行,将输入的N个数,放到一个数组ARRAY当中,然后显示排序前后数组的元素。

代码改自:https://www.cnblogs.com/Coder-L/p/11006357.html

因为目前水平有限,有一些代码几乎是重复的,所以代码量有点多。以后再来改。
不过代码每个步骤都有写明,认真看一遍应该是没问题的。

以下是随便写的一个调试程序:
在这里插入图片描述

DATAS SEGMENT
    ;此处输入数据段代码
    OUTPUT1 DB 'How many data to input? (less than or equal to 100):',0AH,0DH,'$'
    OUTPUT2 DB 'Input ','$'
    OUTPUT2_1 DB ' datas,press [Enter] after input each data.',0AH,0DH,'$'
    OUTPUT3 DB 'Before sorting: ','$'
    OUTPUT4 DB 'After sorting: ','$'
    OUTPUT5 DB 'ERROR: OVERFLOW! Please input again:','$'
	
    ARRAY DW 100 DUP(?) 
    M DW ?,'$'
     
DATAS ENDS

STACKS SEGMENT
    ;此处输入堆栈段代码
    DW 256 dup(?)
STACKS ENDS

CODES SEGMENT
    ASSUME CS:CODES,DS:DATAS,SS:STACKS
START:
    MOV AX,DATAS
    MOV DS,AX
;----------------------------
;输出“How many data to input? (less than or equal to 100):”
    LEA DX,OUTPUT1
    MOV AH,09H
    INT 21H
    
;----------------------------
;输入一个数,并将其存入M

    CALL Input1
;----------------------------
;输出“Input M datas,press [Enter] after input each data.”     

    LEA DX,OUTPUT2
    MOV AH,09H
    INT 21H
    CALL Print1
   	LEA DX,OUTPUT2_1
    MOV AH,09H
    INT 21H

;--------------
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值