| 查看: 1547 | 回复: 13 | |||
[交流]
【求助】50金币求大家帮忙改一段程序
|
|||
|
有一组数据如下所示,第一列代表istep变化范围(1-5000),第二列ia(1-30000),第三列ib(1-800),现在我想用一个三维数组H(istep,ia,ib)来标记这些数据,同一行数字定义的H=1,其他的H均为0.也就是说当istep=1时,ia=781,ib=455时H=1。我的主要目的就是能够将istep,ia,ib用一个函数联系起来,因为在程序后面要用这个函数作为进一步的判断条件。我写了一个程序: program exam implicit none integer ia,ib,istep integer ::h(5000,30000,800) integer i h=0 open (10,file='test.out') do i=1,99999999 read(10,*,end=2,err=2) istep,ia,ib h(istep,ia,ib)=1 enddo 2 continue close(10) do ia=1,30000 do ib=1,800 do istep=1,5000 h(istep)=h(istep,ia,ib) enddo do ntel=1,nsteps if(h(ntel)/=0) then 进行后面的程序 ----------------- endif enddo enddo enddo end 但是现在的问题是,定义的三维数组h太大了,程序不能运行, 请大家帮忙看看应该怎么办?先谢了 数据: 1 758 22 1 820 245 1 2050 399 1 2587 232 1 15733 34 1 18193 65 1 20718 256 2 820 245 2 2050 399 2 2587 232 2 20251 125 3 758 22 3 820 245 3 1817 625 3 2050 399 3 16723 555 3 18193 65 3 20718 256 --- ---- ---- |
» 猜你喜欢
宿州学院学报
已经有5人回复
青B发送上会通知了吗
已经有14人回复
博士申请
已经有5人回复
4,4二甲基联苯干啥用,有懂得吗
已经有4人回复
西安交大新媒学院副院长用撤稿论文结题
已经有7人回复
论文撤稿了
已经有9人回复
化学专业申博
已经有5人回复
招收2026级博士生
已经有5人回复
医学类期刊求推荐
已经有6人回复
26/27申博自荐
已经有10人回复
» 本主题相关价值贴推荐,对您同样有帮助:
【急】请大家帮忙看一下这个offer是否合乎要求,新手散光所有金币求助~~
已经有12人回复
帮忙修改一段我的翻译,好难翻啊555
已经有4人回复
也请高人指点,帮忙看看每位评委的意见是什么?(50金币,回帖1金币)
已经有84人回复
帮忙修改一段翻译!谢谢!
已经有3人回复
求高手帮忙改一下英文摘要
已经有12人回复
【求助】撒点金币请大家帮忙出主意,回国都带什么礼物啊
已经有20人回复
急求,30分钟内翻译一段文字(药学),30分钟内完成6金币再追加50金币
已经有1人回复
再求一段英译中,在线等,急,50金币
已经有5人回复
【求助】10金币请帮忙修改一下MATLAB程序
已经有9人回复
» 抢金币啦!回帖就可以得到:
公众号有偿招募推文
+1/476
华南师范大学海洋环境科学课题组招聘青年英才和博士后
+2/134
半导体封测的“最后一公里”,为什么越来越需要“与世隔绝”的环境?
+1/91
薄膜断层光谱仪,看透薄膜内部!🔍
+1/87
新西兰奥克兰大学计算机CS招PhD及访问学者
+1/81
江苏大学优青 胡兴好教授课题组博士后招聘
+1/81
福州大学化工学院电子化学品团队博士招生,还有一个名额!
+1/75
真诚才是必杀技
+1/63
【急招】 北京工业大学 第二批博士申请-杰青课题组1-2名额,25日截止!!
+1/40
【通知】北京信息科技大学仪器科学与光电工程学院招收调剂生(2026),快来报名吧!
+1/37
【截止2026年5月31日】石家庄铁道大学智能交通课题组诚招理工科背景博士
+1/10
【通知】北京信息科技大学仪器科学与光电工程学院招聘优秀师资!
+1/9
南京农业大学2026年申请考核制博士招生:最后一批啦!
+1/8
杭州师范大学博士后招聘
+1/6
电子科技大学材料学院SFT创新中心招收准备考硕和读博的科研助理 理工医交叉方向
+1/6
中南林院士团队 招 生物质能源与材料 博士生
+1/4
【有偿访谈招募】高才通来港后,你过得还好吗?
+1/3
【皇家墨尔本理工大学】招大模型安全博士
+1/2
空间组学入门:GeoMx® DSP核心原理、实验流程与科研应用
+1/2
易度质量流量计在微孔加工流通性测试中的应用
+1/1
4楼2011-03-28 23:54:35
|
以我的第一行数据 1 758 22 为例,1代表istep,758代表ia,22代表ib。 我想用函数将istep,ia,ib联系起来,只有当取我数据中一行上的数字时,定义的函数h=1,其他的h均为0.以第一行为例, istep=1,ia= 758,ib=22时,h=1.或者用多个函数也行,只要能完成后面循环中判断( if(h(ntel)/=0) then)就行。 do ia=1,30000 do ib=1,800 do istep=1,5000 h(istep)=h(istep,ia,ib) enddo do ntel=1,nsteps if(h(ntel)/=0) then 进行后面的程序 ----------------- endif enddo enddo enddo |
5楼2011-03-29 03:05:47
6楼2011-03-29 15:16:15
|
nstep可以写成5000, 对我的文件(new_total.out)的说明: 文件的格式为默认写入格式。 第一列代表ia,第二列ib,第三列istep(变化范围1-5000) 文件所在网址:http://good.gd/1078236.htm [ Last edited by astringent on 2011-3-30 at 05:47 ] |
7楼2011-03-30 05:44:34
8楼2011-03-30 09:01:35
|
可能是我的表达有问题。 我的数据: 1 758 22 1 820 245 1 2050 399 1 2587 232 1 15733 34 1 18193 65 1 20718 256 2 820 245 2 2050 399 2 2587 232 2 20251 125 3 758 22 3 820 245 3 1817 625 3 2050 399 3 16723 555 3 18193 65 3 20718 256 现有一数据文件test.out,文件结构:第一列istep,第二列ia,第三列ib。istep的变化范围是从1到5000,ia的变化范围是从1到30000,ib的变化范围是从1到800。定义一个三维数组h(5000,30000,800),当h的三维取文件中一行数据时,h=1,否者h=0。我的想法是:从test.out文件读入数据,每读一行(即istep,ia,ib),就将相应的h(istep,ia,ib)赋值为1.相应的程序我是这样写的: program exam implicit none integer ia,ib,istep integer ::h(5000,30000,800) integer i h=0 open (10,file='test.out') do i=1,99999999 read(10,*,end=2,err=2) istep,ia,ib h(istep,ia,ib)=1 enddo 2 continue close(10) 当读完文件,就有了三维数组h中每个元素的值(0或1),然后用h是否等于0来做判断条件,进行下面的计算。相应的程序为 do istep=1,5000 do ia=1,30000 do ib=1,800 if (h(istep,ia,ib)/=0) then 进行计算--- endif enddo enddo enddo 但是如果像我这样定义三位数组的话,需要的内存太大,程序不运行,所以想请大家帮忙看看,如何修改程序,才能使程序执行判断条件后面的计算。举个例子,当istep=1,ia,ib只有取文件中的值也就是下面这些数据对应h才等于1,可以进行后面的计算。取其他的值时h均为0,不进行后面的计算。 1 758 22 1 820 245 1 2050 399 1 2587 232 1 15733 34 1 18193 65 1 20718 256 |
9楼2011-03-31 01:08:16
10楼2011-03-31 07:12:45
★ ★
微尘、梦想(金币+2): 谢谢回复…… 2011-04-07 17:39:19
微尘、梦想(金币+2): 谢谢回复…… 2011-04-07 17:39:19
说实话,你解释了那么多还是没有看懂 ![]() ![]() ![]() ![]() 我的理解是这样的: 对于你的 test.out 来说,你想进行下面的计算,前提是,ia 和 ib 是来自于同一个 istep 的,也就是说,如果 istep == 1,那么 ia 和 ib 应该是: 1 758 22 1 820 245 1 2050 399 1 2587 232 1 15733 34 1 18193 65 1 20718 256 如果 istep == 2,那么下面的数据参加计算: 2 820 245 2 2050 399 2 2587 232 2 20251 125 是这样的吗? |
11楼2011-03-31 10:11:20
12楼2011-04-01 01:43:51
13楼2011-04-01 01:51:45
14楼2011-04-01 09:48:18
简单回复
纳米材料7532楼
2011-03-23 07:23
回复
astringent(金币+5): 2011-04-25 19:59:50
帮
!
zyxme3楼
2011-03-23 08:20
回复













回复此楼
