assume cs:cseg,ds:dseg
dseg segment stack
sushu dw 50h dup (?);创建一个50个字节的空数据用于放素数
dseg ends
cseg segment
start: mov ax,dseg;连接段寄存器
mov ds,ax
mov cx,100;100 个数字并循环100次
sort: push cx;入栈
mov si,0;指针归零
inner:
mov ax,cx;将cx的值给了ax
mov bx,2;从2开始除
xxun:
div bx;ax除bx并将结果商放在al余数放在ah
cmp ah,0;比较余数和0
je dxun;相等则跳出小循环
inc bx;不相等则bx自加,用于下一次的除数
mov ax,cx
mov dx,2h
div dx;将cx除以2,并与除数比较,不小于除数则进行再次循环,如果小于则说明是素数
cmp ax,bx
jae xxun
noswap:
mov [si],cx;将素数存入并再次循环
add si,2
loop inner;跳转并将cx的值减一
pop cx;出栈
jmp shuchu
dxun:
loop inner
pop cx
jmp shuchu
shuchu:
lea dx,sushu;输出素数
mov ah,09h
int 21h
mov ax,4c00h;结束程序
int 21h
cseg ends
end start