求出首地址为DATA的10d字数组中的最小偶数,并把它存放在ax中

本文介绍了一个使用汇编语言编写的简单程序,该程序从预定义的数据数组中查找并输出最小的偶数值。通过循环遍历数组并利用位操作判断每个元素是否为偶数,进而确定最小偶数。
DATAS SEGMENT
    ;此处输入数据段代码 
    data dw 1,2,3,4,5,6,7,8,9,10 
DATAS ENDS

STACKS SEGMENT
    ;此处输入堆栈段代码
STACKS ENDS

CODES SEGMENT
    ASSUME CS:CODES,DS:DATAS,SS:STACKS
START:
    MOV AX,DATAS
    MOV DS,AX
    ;此处输入代码段代码
    
    mov bx,0
    mov cx,10
    compare:
    	mov ax,data[bx]		;取数组的第一个偶数
    	add bx,2
    	test ax,01h			;是偶数吗?
    	loopnz compare		;不是,比较下一个
    	jnz stop			;没有偶数,退出
    	jcxz stop			;最后一个是偶数,即为最小偶数
    compare1:
    	mov dx,data[bx]		;取数组的下一个偶数
    	add bx,2
    	test dx,01h			;是偶数吗?
    	jnz next			;不是,比较下一个数
    	cmp ax,dx			;(ax)<(dx)吗?
    	jle next			
    	mov ax,dx			;(ax)<(dx),则置换(ax)为最小偶数
    next:
    	loop compare1
   
   stop: 
   	mov dl,al
   	add dl,'0'
   	mov ah,2
   	int 21h
   	
    MOV AH,4CH
    INT 21H
CODES ENDS
    END START
5.1试编写一个汇编语言程序,要对键盘输入的小写母用大写母显示出来。 5.2 编写程序,从键盘接收一个小写母,然后找出它的前导符和后续符,再按顺序输出 5.3 将AX寄存器中的16位数分成4组,每组4位,然后把这四组数分别放在AL、BL、CL、DL中。 5.4 试编写一程序,要比较两个符串STRING1和STRING2所含符是否相同,若相同则显示‘MATCH’,若不相同则显示‘NOT MATCH’。 5.5 试编写一程序,要能从键盘接收一个个位数N,然后响铃N次。 5.6 编写程序,将一个包含有20个数据的数组M分成两个数组:正数数组P和负数数组N,分别把这两个数中的数据个数显示出来。 5.7 试编制一个汇编语言程序,求出首地址DATA100D数组中的最小偶数把它放在AX中。 5.8 把AX存放的16位二进制数K看作是8个二进制的“四分之一字节”。试编写一个程序,要数一下值为3(即11B)的四分之一字节数,将该数在终端上显示出来。 5.9 试编写一汇编语言程序,要从键盘接收一个四位的十六进制数,在终端上显示与它等值的二进制数。 5.10 设有一段英文,其符变量名为ENG,以$符结束。试编写一程序,查对单词SUN在该文中的出现次数,以格式”SUNXXXX“显示出次数。 5.11 从键盘输入一系列以$为结束的符串,然后对其中的非数符进行计数,显示出计数结果。 5.12 有一个首地址为MEM的100D数组,试编制程序删除数组中所有为零的项,将后续项向前压缩,最后将数组的剩余部分补上零。 5.13 在STRING到STRING+99单元存放着一个符串,试编制一程序测试该符串中是否存在数,如有,则把CL的第五位置1,否则置0. 5.14 在首地址为TABLE的数组中按递增次序存放100H个16位补码数,试编写一个程序把出现次数最多的数及其出现的次数分别放在AX和CX中。 5.15 数据段中已定义了一个有N个数据数组M,试编写一程序求出M中绝对值最大的数,把它放在数据段的M+2n单元中,将该数的偏移地址存放在M+2(n+1)单元中。 5.16 在首地址DATA数组中,存放100H个16位补码数,试编写一个程序求出它们的平均值放在AX寄存器中;求出数组中有多少个数小于此平均值,将结果放在BX寄存器中。 5.17 试编写一个程序,把AX中的十六进制数转换为ASCII码,将对应的ASCII码依次存放到MEM数组中的四个字节中,例如:当(AX)=2A49H时,程序执行完后,MEM中的4个字节的内容为39H,34H,41H和32H。 5.18 把0~100D之间的30个数存入以GRADE为首地址的30个数组中,GRADE+i表示学号i+1的学生的成绩。另一个数组RANK为30个学生的名次表,其中RANK+i的内容是学号为i+1的学生的名次。编写一程序,根据GRADE中的学生成绩,将学生名次填入RANK数组中。 5.19 已知数组A包含15个互不相等的整数,试编写一程序,把既在A中又在B中出现的整数存在于数组中C中。 5.20 设在A,B和C单元存放着三个数,若三个数都不是0,则求出三树之和存放于D单元中;其中有一个数为0,则把其他两个数也清零。试编写此程序。
module fmft implicit none integer,parameter,private::NPMAX=2**12 integer,parameter,private::NPKMAX=20 integer,parameter,private::NPKMAX2=NPKMAX*2 double precision,private::dat0_mft(NPMAX),dat1_mft(NPMAX),dat_mft(NPMAX) double precision,private::dat0_fmft1(NPMAX),dat1_fmft1(NPMAX),dat_fmft1(NPMAX) double precision,private::dat0_fmft2(NPMAX),dat1_fmft2(NPMAX),dat_fmft2(NPMAX) integer,private:: npts_mft,npts_fmft1,npts_fmft2 ! the real length of the input data double precision,private:: dt_mft,dt_fmft1,dt_fmft2 double precision,private:: tt_mft,tt_fmft1,tt_fmft2 contains subroutine mft(x,dt,pkfs,pkas,npk) implicit none integer::npk integer::nh,ntry,nflag integer:: i,n double precision:: fr,fn ! spectrum reolution and the Nyquist frequency double precision:: fmin,fmax,df,ftest ! boundary of the one-dimensional search and the stepsize double precision:: ax,bx,cx,dx ! variables for one-dimensional search double precision:: dt double precision:: pkf,pka double precision:: pkfs(:),pkas(:),x(:) double precision:: pars(40) call ini_mft(x,dt,nflag) ! print*,size(pkfs),npkmax if(size(pkfs).gt.npkmax)then nflag=0 endif print*,"nflag=",nflag call global_print() fr=1d0/2d0/dt_mft/dble(npts_mft) ! resolution of the frequency fn=1d0/2d0/dt_mft ! Nyquist frequency npk=0 print*,"fr,fn",fr,fn do while(npk.le.2) npk=npk+1 call find_pkf_fft(dat_mft(1:npts_mft),dt,pkf) fmax=pkf+fr fmin=pkf-fr df=(fmax-fmin)/1d2 if(fmax.ge.fn)fmax=fn-1d-10 if(fmin.le.0d0)fmin=1d-10 nh=1 do i=1,100 ftest=fmin+dble(i)*df print*,ftest print*,npts_mft,dt_mft print*,ntry print*,ftest,func_amp_hanning(ftest,pars,nh,ntry) end do enddo end subroutine mft subroutine ini_mft(x,dt,nflag) implicit none double precision:: x(:) double precision:: dt,tt integer::nflag,npts nflag=1 dat0_mft(1:npmax)=0d0 dat_mft(1:npmax)=0d0 dat1_mft(1:npmax)=0d0 npts=size(x) if(npts.gt.npmax)then print*,"input error" nflag=1 pause return endif dt_mft=dt dt_fmft1=dt dt_fmft2=dt npts_mft=npts npts_fmft1=npts npts_fmft2=npts tt=dble(npts)*dt tt_mft=tt tt_fmft1=tt tt_fmft2=tt dat0_mft(1:npts)=x(1:npts) dat_mft(1:npts)=dat0_mft(1:npts) dat1_mft(1:npts)=dat0_mft(1:npts) end subroutine ini_mft subroutine find_pkf_fft(x,dt,pkf) ! find the peak frequency with the largest amplitude by employing the FFT(DFT) method implicit none integer:: i,i2 integer:: n,nhalf double precision:: pkf,pka double precision:: dt double precision:: x(:) double precision:: x0(size(x)),x1(size(x)) double precision:: freqs(size(x)/2),amps(size(x)/2) n=size(x) nhalf=n/2 x0(1:n)=x(1:n) call drealft(x0,n,1) ! FFT to the frequency domain x0(1:n)=x0(1:n)/dble(nhalf) do i=1,nhalf-1 i2=i*2 freqs(i)=dble(i)/dble(n)/dt amps(i)=dsqrt(x0(i2+1)**2+x0(i2+2)**2) end do freqs(nhalf)=1d0/dt/2d0 amps(nhalf)=dabs(x0(1)/2d0) ! do i=1,20 ! print*,i,freqs(i),amps(i),x0(i),x(i) ! end do pkf=freqs(2) pka=amps(2) do i=3,nhalf-1 if(amps(i).ge.pka)then pka=amps(i) pkf=freqs(i) endif end do print*,"PKF,PKA",PKF,PKA end subroutine find_pkf_fft SUBROUTINE drealft(dat,n,isign) INTEGER isign,n DOUBLE PRECISION dat(n) INTEGER i,i1,i2,i3,i4,n2p3 DOUBLE PRECISION c1,c2,h1i,h1r,h2i,h2r,wis,wrs DOUBLE PRECISION theta,wi,wpi,wpr,wr,wtemp theta=3.141592653589793d0/dble(n/2) c1=0.5d0 if (isign.eq.1) then c2=-0.5d0 call dfour1(dat,n/2,+1) else c2=0.5d0 theta=-theta endif wpr=-2.0d0*sin(0.5d0*theta)**2 wpi=sin(theta) wr=1.0d0+wpr wi=wpi n2p3=n+3 do i=2,n/4 i1=2*i-1 i2=i1+1 i3=n2p3-i2 i4=i3+1 wrs=wr wis=wi h1r=c1*(dat(i1)+dat(i3)) h1i=c1*(dat(i2)-dat(i4)) h2r=-c2*(dat(i2)+dat(i4)) h2i=c2*(dat(i1)-dat(i3)) dat(i1)=h1r+wrs*h2r-wis*h2i dat(i2)=h1i+wrs*h2i+wis*h2r dat(i3)=h1r-wrs*h2r+wis*h2i dat(i4)=-h1i+wrs*h2i+wis*h2r wtemp=wr wr=wr*wpr-wi*wpi+wr wi=wi*wpr+wtemp*wpi+wi end do if (isign.eq.1) then h1r=dat(1) dat(1)=h1r+dat(2) dat(2)=h1r-dat(2) else h1r=dat(1) dat(1)=c1*(h1r+dat(2)) dat(2)=c1*(h1r-dat(2)) call dfour1(dat,n/2,-1) endif return END SUBROUTINE Drealft SUBROUTINE dfour1(dat, nn, isign) IMPLICIT NONE INTEGER, INTENT(IN) :: nn, isign DOUBLE PRECISION, DIMENSION(2*nn), INTENT(INOUT) :: dat INTEGER :: i, j, m, mmax, n, istep DOUBLE PRECISION :: tempr, tempi DOUBLE PRECISION :: theta, wi, wpi, wpr, wr, wtemp n = 2 * nn j = 1 DO i = 1, n, 2 IF (j > i) THEN tempr = dat(j) tempi = dat(j+1) dat(j) = dat(i) dat(j+1) = dat(i+1) dat(i) = tempr dat(i+1) = tempi END IF m = n / 2 DO WHILE ((m >= 2) .AND. (j > m)) j = j - m m = m / 2 END DO j = j + m END DO mmax = 2 DO WHILE (n > mmax) istep = 2 * mmax theta = 6.28318530717959d0 / (isign * mmax) wpr = -2.d0 * SIN(0.5d0 * theta)**2 wpi = SIN(theta) wr = 1.d0 wi = 0.d0 DO m = 1, mmax, 2 DO i = m, n, istep j = i + mmax tempr = wr * dat(j) - wi * dat(j+1) tempi = wr * dat(j+1) + wi * dat(j) dat(j) = dat(i) - tempr dat(j+1) = dat(i+1) - tempi dat(i) = dat(i) + tempr dat(i+1) = dat(i+1) + tempi END DO wtemp = wr wr = wr * wpr - wi * wpi + wr wi = wi * wpr + wtemp * wpi + wi END DO mmax = istep END DO END SUBROUTINE dfour1 subroutine global_print() ! subroutine used to print all the global variables ! defined inside the module print*,"the initial length of the data is",NPMAX print*,"the real length is",npts_mft print*,"the sampling inteval is",dt_mft print*,"the total time is",tt_mft end subroutine global_print function func_amp_hanning(fre,pars,nh,nflag) implicit none integer,intent(In):: nh double precision,intent(in):: fre integer:: i,nflag,ntry double precision:: pi,dpi,rad double precision:: t double precision:: func_amp_hanning,amp,sf,cf double precision:: pars(40) print*,"inside the function func_amp_hanning" pi=dacos(-1d0) dpi=2d0*PI rad=pi/180d0 nflag=1 ! print*,"npts_mft in func_amp_hanning is",npts_mft print*,"dat0 or dat,dat!!!" ! sf=0d0 ! cf=0d0 ! do i=1,1 !npts_mft ! t=dble(I)*dt_mft ! cf=cf+dat_mft(i)*dcos(dpi*fre*t)*(1d0-dcos(dpi*t/tt_mft)) ! sf=sf+dat_mft(i)*dsin(dpi*fre*t)*(1d0-dcos(dpi*t/tt_mft)) ! end do ! amp=dsqrt(cf**2+sf**2) ! pars(1)=cf ! pars(2)=sf ! func_amp_hanning=amp return end function func_amp_hanning end module fmft program main_fmft use fmft implicit none integer,parameter::NPTS=2**10,NPTSH=NPTS/2,NPTSQ=NPTS/4 integer,parameter::NPKMAX=20,NPKMAX2=NPKMAX*2 integer:: i,ipk,npk double precision::x0(NPTS),x(NPTS) double precision::pi,dpi,rad double precision:: dt,fre,t double precision::pkf(NPKMAX),PKA(NPKMAX2) pi=dacos(-1d0) dpi=2d0*pi rad=pi/180d0 dt=1d0 fre=1d0/2d0/dt/dble(nptsh)*10d0 do i=1,npts t=dble(I)*dt x0(i)=dcos(dpi*fre*t) ! print*,i,x0(i) end do print*,"fre is",fre pause call mft(x0,dt,pkf,pka,npk) end program main_fmft
最新发布
05-21
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值