#include <stdio.h>
typedef struct list
{int data;
struct list *next;
}LIST;
int fun(LIST *h)
{ LIST *p;//*p是指针的形式,而*p的意义是指针变量p所指向的变量的值,这里*p是一个具体的变量
/**********found**********/
int t;//t是数据结果,t应该定义为0的
p=h;
/**********found**********/
while(*p)//while(*p)的意义是*p不为空时就一直执行,但是这里根据题意我们需要的链表的地址来进行题目需要的链表的计算,而单向链表的结束的标志就是链尾,链尾的特征则是指向为空,这里的终止条件不应该是p所指向的值为0,而是p的地址为空,所以while(*p)应该改为while(p)。
{
/**********found**********/
t=t+p.data;//p.data的意义是p.data这个指针变量,也就是说这是指针变量的运算,我们应该要使用结点的结构体变量。即“=t+p.data”应该改为“t=t+(*p).data”。(同下)
p=(*p).next;
}
return t;
}
main()
{LIST a,b,c,*h;
a.data=34;b.data=51;
c.data=87;c.next='\0';
h=&a;a.next=&b;b.next=&c;
printf("总和 = %d\n",fun(h));
}