私は単純なプログラムでいくつかのデータを配列に読み込もうとして夢中になっています。セグメンテーション違反が発生する理由がわかりません。私のコードは次のように始まります:
program guess_input
implicit none
CHARACTER*2, allocatable, dimension(:) :: element
double precision, allocatable, dimension(:,:) :: xyzq
INTEGER, allocatable, dimension(:) :: label,cs_num, br_num, xx_num
real, allocatable, dimension(:) :: distance
real, allocatable, dimension(:) :: ep
INTEGER :: stat, numatom, i, j
CHARACTER*80 :: line
numatom = 61502
allocate(element(numatom))
allocate(xyzq(4,numatom))
allocate(label(numatom))
OPEN(UNIT=22,FILE='EMBQ_EPF.OUT',iostat=stat)
If(stat.ne.0) Stop "File not found"
!Read in the input into two arrays
do i=1,numatom
READ(22,'(A)') line
READ(line, *) xyzq(1,i), xyzq(2,i), xyzq(3,i), xyzq(4,i), label(i)
enddo
CLOSE(22)
!Define element type in parallel array based on the charge
do i=1,numatom
if(xyzq(4,i) == 1.00) then
element(i) = 'Cs'
elseif(xyzq(4,i) == -1.00) then
element(i) = 'Br'
else
element(i) = 'XX'
endif
enddo
OPEN(33, FILE='element.out')
do i=1,numatom
write(33,*) element(i)
enddo
end program guess_input
障害を切り分けようとしましたが、何が問題なのか本当にわかりません。
どんな助けでも大歓迎です、ありがとう。