Fortran Coder

查看: 10919|回复: 9
打印 上一主题 下一主题

[数值问题] Fortran如何实现1000个变量循环赋10个值

[复制链接]

23

帖子

9

主题

0

精华

熟手

F 币
134 元
贡献
82 点
跳转到指定楼层
楼主
发表于 2017-7-7 14:37:06 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
目下,我有1000个变量,想循环赋10个值,也就是说变量1-10赋值1-10,变量11-20还是赋值1-10,不知道该如何实现,望大家帮助下,多谢
分享到:  微信微信
收藏收藏2 点赞点赞 点踩点踩

954

帖子

0

主题

0

精华

大师

F 币
184 元
贡献
75 点

规矩勋章元老勋章新人勋章水王勋章热心勋章

QQ
沙发
发表于 2017-7-7 15:10:14 | 只看该作者
本帖最后由 vvt 于 2017-7-7 15:16 编辑

[Fortran] 纯文本查看 复制代码
real :: a(1000)
  integer :: i
  Do i = 1 , 10
    a(i::10) = i
  End Do


a( x : y : z ) = i 的意思是,从第x个开始,到第y个结束,每z个数赋值为 i
(其中x忽略则从数据最开始开始y忽略则到数组最尾端结束z忽略则每1个数赋值

所以 a( i : : 10 ) = i 的意思是,从第 i 个到最后一个每10个数赋值为  i


23

帖子

9

主题

0

精华

熟手

F 币
134 元
贡献
82 点
板凳
 楼主| 发表于 2017-7-7 15:18:47 | 只看该作者
vvt 发表于 2017-7-7 15:10
[mw_shl_code=fortran,true]real :: a(1000)
  integer :: i
  Do i = 1 , 10

多谢多谢,刚学写程序好多都不太会。

100

帖子

0

主题

0

精华

专家

F 币
550 元
贡献
291 点

规矩勋章元老勋章

QQ
地板
发表于 2017-7-7 15:27:43 | 只看该作者
还有更简便的写法
[Fortran] 纯文本查看 复制代码
a = reshape(spread([1:10],2,100),shape(a))

它把 [ 1:10 ] 在第 2 个维度上延伸 100 倍。变成 10*100 的二维数组。然后再 reshape 成 a 的外形(即 1000 的一维数组)

23

帖子

9

主题

0

精华

熟手

F 币
134 元
贡献
82 点
5#
 楼主| 发表于 2017-7-7 15:49:31 | 只看该作者
vvt 发表于 2017-7-7 15:10
real :: a(1000)
  integer :: i
  Do i = 1 , 10

我是想这么赋值的,不知道行不行?多谢      
[Fortran] 纯文本查看 复制代码
program aweigh
          implicit real*8 (a-h,o-z)
          dimension wa(10000,1)
          real::a(10000)
          parameter(N=14.00672)
          parameter(H=1.00795)
          parameter(C=12.01078)
          open(13,file='aweigh.txt')
          do i=1,10
            if ((i.eq.1).or.(i.eq.5)) 
                then a(i::10)=N
                endif
                if ((i.eq.3).or.(i.eq.4).or.(i.eq.8)) 
                then a(i::10)=C
                else a(i::10)=H
                endif
      enddo                
          do i=1,10000
          write(3,*)a(i)
          enddo
          close(13)
          end

23

帖子

9

主题

0

精华

熟手

F 币
134 元
贡献
82 点
6#
 楼主| 发表于 2017-7-7 16:15:17 | 只看该作者
百事可乐 发表于 2017-7-7 15:27
还有更简便的写法

...

多谢多谢

954

帖子

0

主题

0

精华

大师

F 币
184 元
贡献
75 点

规矩勋章元老勋章新人勋章水王勋章热心勋章

QQ
7#
发表于 2017-7-7 16:31:26 | 只看该作者
[Fortran] 纯文本查看 复制代码
program aweigh
  implicit none !//这句话非常非常重要!!请一定要写 implicit none
  real(8) :: a(10000)
  integer :: i
  Real(8) , parameter :: N=14.00672 !// N 要定义成 real8 
  Real(8) , parameter :: H=1.00795
  Real(8) , parameter :: C=12.01078
  open(13,file='aweigh.txt')
  do i=1,10
    Select Case( i ) !//用 Select 语句,方便直观
    Case(1,5)
      a(i::10)=N
    Case(3,4,8)
      a(i::10)=C
    Case Default
      a(i::10)=H
    End Select
  enddo
  do i=1,10000
    write(3,*)a(i)
  enddo
  close(13)
end program aweigh

23

帖子

9

主题

0

精华

熟手

F 币
134 元
贡献
82 点
8#
 楼主| 发表于 2017-7-7 16:42:00 | 只看该作者
vvt 发表于 2017-7-7 16:31
[mw_shl_code=fortran,true]program aweigh
  implicit none !//这句话非常非常重要!!请一定要写 implici ...

多谢多谢

47

帖子

3

主题

0

精华

大师

F 币
1634 元
贡献
119 点

规矩勋章

9#
发表于 2017-7-16 09:56:15 | 只看该作者
学习了,很不错

130

帖子

10

主题

0

精华

大师

F 币
617 元
贡献
372 点

贡献勋章管理勋章帅哥勋章元老勋章星光勋章规矩勋章

10#
发表于 2017-8-12 19:36:05 | 只看该作者
1. 樓主有興趣"學習語法"的話, 可進一步把vvt(7#)範例, 用FORALL改寫
2. 請樓主沒事別用"double precision", 突顯自己的無知而已

[Fortran] 纯文本查看 复制代码
PROGRAM test
  IMPLICIT NONE
  ! "(8)" compiler dependent (NAG/Silverfrost not accept), avoid to use
  REAL(8) , PARAMETER :: N=14.00672
  REAL(8) , PARAMETER :: H= 1.00795
  REAL(8) , PARAMETER :: C=12.01078

  INTEGER, PARAMETER :: r8=SELECTED_REAL_KIND(P=15)
  REAL(r8) , PARAMETER :: NN=14.00672_r8
  REAL(r8) , PARAMETER :: HH= 1.00795_r8
  REAL(r8) , PARAMETER :: CC=12.01078_r8

  WRITE(*,*) N, NN
  WRITE(*,*) H, HH
  WRITE(*,*) C, CC
END PROGRAM test


3. 蒐集到的資料, 請參考:

precision.pdf

168.19 KB, 下载次数: 3

您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

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

GMT+8, 2024-12-26 08:55

Powered by Tencent X3.4

© 2013-2024 Tencent

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