Fortran Coder

查看: 10391|回复: 5
打印 上一主题 下一主题

[输入输出] 二维数组赋值出错

[复制链接]

1968

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1376 元
贡献
583 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

楼主
发表于 2018-10-7 22:47:48 | 显示全部楼层
是格式问题呀。
b 是浮点数,不能用 I 编辑符。(因为 I 编辑符只针对整型)
其他意见,见下面代码的注释内容。

[Fortran] 纯文本查看 复制代码
program main
  implicit none
  Integer , parameter :: NX = 521 , NY = 1440 , SLAND = -999!//定义常量,以便容易修改
  character(*),parameter :: infile='Depth.01',outfile='Depth2.01'
  integer :: i,j
  real,dimension(NX,NY):: m, b

  OPEN(UNIT=20,FILE=infile)
  OPEN(UNIT=30,FILE=outfile,status='replace',action='write')
  !读取文件
  do i=1,NX
    read(20,*,end=99) m(i,:)!//数组片段,简化代码
  enddo
  !赋值
  do i=1,NX
    do j=1+3,NY-3
      if(m(i,j)==SLAND) then
        b(i,j)=1
      else if(m(i,j)/=SLAND.and.m(i,j+1)==SLAND) then!//此处是否m(i,j+1)??
        b(i,j-3:j)=2!//数组片段,简化代码
      else if(m(i,j)==SLAND .and. m(i,j+1)/=SLAND) then
        b(i,j:j+3)=2!//数组片段,简化代码
      else if (m(i,j)<200) then
        b(i,j)=2
      else
        b(i,j)=m(i,j)
      endif
    enddo
  enddo
  !写入新文件
  do i=1,NX
    write(30,'(*(f13.4))') b(i,:)!// *(f13.4) 表示有多少个算多少个。
  end do
99 close(20)!//良好的关闭文件习惯
   close(30)
end program main

1968

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1376 元
贡献
583 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

沙发
发表于 2018-10-8 14:45:43 | 显示全部楼层
write(30,'(*(f13.4))') b(i,1+3:NY-3)

1968

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1376 元
贡献
583 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

板凳
发表于 2018-10-8 16:36:49 | 显示全部楼层
1. 出错请给错误提示。
2. 让别人调试,请提供输入数据文件。
3. 你说“能不能保留呢?”,我不知道保留成什么?涉及到程序逻辑问题,请描述清楚。
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-6-12 16:20

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表