C语言链表问题,高分悬赏,请问这2哥函数怎么用,还有struct node*h = createlist()是什么意思 100

#include<stdio.h>#include<stdlib.h>structnode{intdata;structnode*next;};structnode*cr... #include<stdio.h>
#include<stdlib.h>

struct node
{
int data;
struct node *next;
};
struct node* createlist()
{
int data;
struct node*p,*q=NULL,*h=NULL;
while(1)
{
if((data=getchar())!='\n'&&data!=32)
{
p=(struct node*)malloc(sizeof(struct node));
p->data =data;
if(h==NULL) /*the first tree*/
h=p;
else
q->next=p;
q=p;
}
else if(data=='\\')
break;
}
if(q!=NULL)
q->next =NULL;
return h;
}

int main()
{
struct node * h = createlist();

return 0;
displist();
}
int displist(struct node*h)
{
struct node*p =h;
while(p!=NULL)
{
printf("%4c",p->data);
p=p->next ;
}
}
展开
 我来答
kaixingui2012
2013-08-16 · TA获得超过4.2万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:6194万
展开全部
int main()
{
struct node * h = createlist(); //这是调用创建链表函数,返回表头指针 给h
displist( h ); //这个函数调用 缺少了参数
return 0; //程序遇到Return命令就会返回函数调用者,若main中,就会返回系统,即程序退出
}
点点点循环
2013-08-16 · TA获得超过256个赞
知道小有建树答主
回答量:257
采纳率:0%
帮助的人:85万
展开全部
struct node* createlist()
这是一个函数,返回类型是struct node*,那么struct node* h = createlist();就是让h等于createlist()函数返回的指针。

main函数中的
return 0;
displist();
displist()函数这样是不会执行的,因为return 0已经表示返回了。
追问
那怎么操作啊。我网上找到一个
typedef struct NodeType
{
ElemType data;
struct NodeType *next;
} NodeType,*LinkType;
这个时候 linktype是带*的
void output(LinkType head)
,为什么调用的时候就没有 * 了呢,能不能加个Q.Q,我有好多问题,分数当然不是问题
追答
可以 60 56 45324
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式