24小时热门版块排行榜    

CyRhmU.jpeg
南方科技大学公共卫生及应急管理学院2025级博士研究生招生报考通知
查看: 637  |  回复: 3
当前主题已经存档。
本帖产生 2 个 程序强帖 ,点击这里进行查看

ningqicheng

铁虫 (初入文坛)

[交流] 【求助】指针问题??已有3人参与

1.module typedef
2.  implicit none
3.  type :: datalink
4.    integer :: i
5.    type(datalink), pointer :: next
6.  end type datalink
7.end module typedef
8.
9.program ex1012
10.  use typedef
11.  implicit none
12.  type(datalink) , pointer :: p, head
13.  integer :: i,n,err
14.
15.  write(*,*) 'Input N:'
16.  read(*,*) n
17.
18.  allocate( head )
19.  head%i=1
20.  nullify(head%next)
21.
22.  p=>head
23.  do i=2,n
24.    allocate( p%next, stat=err )
25.    if ( err /= 0 ) then
26.      write(*,*) 'Out of memory!'
27.      stop
28.    end if
29.    p=>p%next
30.    p%i=i
31.  end do
32.  nullify(p%next)
33.
34.  p=>head
35.  do while(.true.)
36.    write(*, "(i5)" ) p%i
37.        if ( .not. associated(p%next) ) exit
38.    p=>p%next
39.  end do
40.
41.  stop
42.end program
这是自动创建串行的程序。主要是12行到32,怎么也读不懂,有没有高人指点一下??谢谢了
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

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的回帖

ningqicheng

铁虫 (初入文坛)

我不理解为什么:20.  nullify(head%next),去掉不行吗?
还有24.    allocate( p%next, stat=err ),为什么不是allocate(p,stat=err)
还有就是C语言中有头指针概念,这里建立链表的时候好像没有用它,直接就是头结点,是不是有什么问题?
3楼2010-04-10 09:13:28
已阅   回复此楼   关注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 的主题更新
普通表情 高级回复(可上传附件)
信息提示
请填处理意见