回 帖 发 新 帖 刷新版面

主题:fortran编程,对均匀圆环进行编程。但是运行计算不出数据

PROGRAM SURFACESLIDER
DIMENSION S(361),R(121),H(361,121)
COMMON /COM1/DS,DR,H0
DATA N,M,PI,H0/361,121,3.1415926,0.05/

OPEN(9,FILE='FILM.DAT',STATUS='UNKNOWN')
CALL SUBH(N,M,S,R,H)
CALL OUTPUT(N,M,S,R,H)
STOP
END


SUBROUTINE SUBH(N,M,S,R,H)
DIMENSION s(N),R(M),H(N,M)
COMMON /COM1/DS,DR,H0


PI=3.1415926
    H0=0.05

s_min=0
s_max=2*PI
r_min=80
r_max=100
   

    DS=(s_max-s_min)/(N-1.0)
    DR=(r_max-r_min)/(M-1.0)

   DO I=1,N
    S=S_MIN+(I-1)*DS
    H(I,:)=S
    ENDDO

    DO J=1,M
    R=R_MIN+(J-1)*DR
    H(:,J)=R
ENDDO
  
   
DO J=1,80
    H(I,J)=0
enddo

DO J=80,M
H(I,J)=H0
ENDDO

RETURN
END

SUBROUTINE OUTPUT(N,M,S,R,H)
DIMENSION S(N),R(M),H(N,M)
COMMON /COM1/DS,DR,H0

WRITE(9,40)R(1),(R(J),J=1,M)
DO I=1,N
WRITE(9,40)S(I),(H(I,J),J=1,M)
ENDDO
40 FORMAT(122(E12.6,1X))
STOP

END


回复列表 (共3个回复)

沙发

数组越界,怎么解决?

板凳

有两个问题:

1   相对来说,数组越界是很好解决的问题,应当在程序中插入输出,看在哪里越界,

2   pi=4*atan(1.0),这个是标准的说法,很显然,你的数据会导致出问题。


3 楼

幸运飞艇在选择彩种来投注的过程中彩票,大家往往希望通过最少的付出来获得最高的回报福彩双色球

我来回复

您尚未登录,请登录后再回复。点此登录或注册