24小时热门版块排行榜    

CyRhmU.jpeg
查看: 641  |  回复: 3
当前主题已经存档。
本帖产生 2 个 程序强帖 ,点击这里进行查看
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

tjyl

金虫 (正式写手)

★ ★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
jjdg(金币+1):感谢回帖交流! 2010-04-10 00:45
nono2009(金币+2, 程序强帖+1):多谢专家。 2010-04-10 13:09
这个和C里面的单向链表一样的啊。
13-17就是问你要创建多少个节点。18-20就是先为头结点分配内存,设置好值。
23-32就是逐个为节点分配内存,把第i个节点里的值设置为i,32行就是把末尾的节点里指向datalink的指针的值设置为不可访问的地址。
2楼2010-04-09 20:33:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

holmescn

金虫 (正式写手)

★ ★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
nono2009(金币+3, 程序强帖+1):多谢专家。 2010-04-10 13:09
引用回帖:
Originally posted by ningqicheng at 2010-04-10 09:13:28:
我不理解为什么:20.  nullify(head%next),去掉不行吗?
还有24.    allocate( p%next, stat=err ),为什么不是allocate(p,stat=err)
还有就是C语言中有头指针概念,这里建立链表的时候好像没有用它,直接就是 ...

这可能缘于fortran的指针和C是不一样的,C里直接给指针赋值为0就代表(公认的,并不是语法规定的)空指针。而fortran里需要用nullify来给一个指针变量赋值为空。

同样因为fortran里的指针概念的不同,在Fortran里,每个对象的传递都是有指针完成的,所以head,既代表了头结点也代表了头指针。而p指针是要在链表里游走的。当然你也可以allocate(p)作为开始,但没有地方保存头指针了。

而allocate(p%nest)而不是allocate(p)这个问题你还是没有搞明白链表是怎么回事。p指向当前结点,而当前节点已经分配了啊,当然要allocate(p%next)了。
4楼2010-04-10 09:57:43
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ningqicheng 的主题更新
普通表情 高级回复(可上传附件)
信息提示
请填处理意见