标题:哪个好呀?
只看楼主
win200301
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2007-12-8
 问题点数:0 回复次数:2 
哪个好呀?
#include <stdio.h>
#include <malloc.h> /*包含动态内存分配函数的头文件*/
#define N 10 /*N为人数*/
typedef struct node
{
char name[20];
struct node *link;
}stud;

stud * creat(int n) /*建立单链表的函数,形参n为人数*/
{
stud *p,*h,*s; /* *h保存表头结点的指针,*p指向当前结点的前一个结点,*s指向当前结点*/
 int i; /*计数器*/
if((h=(stud *)mscanf("%s",s->name)alloc(sizeof(stud)))==NULL) /*分配空间并检测*/
{
printf("不能分配内存空间!");
exit(0);
}
h->name[0]='\0'; /*把表头结点的数据域置空*/
h->link=NULL; /*把表头结点的链域置空*/
p=h; /*p指向表头结点*/
for(i=0;i<n;i++)
{
if((s= (stud *) malloc(sizeof(stud)))==NULL) /*分配新存储空间并检测*/
{
printf("不能分配内存空间!");
exit(0);
}
p->link=s; /*把s的地址赋给p所指向的结点的链域,这样就把p和s所指向的结点连接起来了*/
printf("please input %d name\t",i+1);
scanf("%s",s->name); /*在当前结点s的数据域中存储姓名*/
s->link=NULL;
p=s;
}
return(h);
}

main()
{
int number; /*保存人数的变量*/
stud *head; /*head是保存单链表的表头结点地址的指针*/
number=N;
head=creat(number); /*把所新建的单链表表头地址赋给head*/
}
main()
{
int number; /*保存人数的变量*/
stud *head; /*head是保存单链表的表头结点地址的指针*/
number=N;
head=creat(number); /*把所新建的单链表表头地址赋给head*/
}





scanf("%s",s->name); /*在当前结点s的数据域中存储姓名*/

这行可不可以这样scanf("%s",p->name);哪个好呀???
搜索更多相关主题的帖子: include 计数器 动态 检测 空间 
2007-12-17 22:08
mcyrdb
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2007-12-8
得分:0 
scanf("%s",s->name); 好。看你的程序当前的p 指向的是s 前一个的节点,所以不能用
scanf("%s",p->name);如果想用则要把p=s这一语句放在scanf("%s",s->name)语句前就可以了。
2007-12-17 22:48
win200301
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2007-12-8
得分:0 
scanf("%s",s->name); 好。看你的程序当前的p 指向的是s 前一个的节点,所以不能用

指向前一节点,就是把名字存在前段内存中嘛~

怎么不可以???
2007-12-18 12:25



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-193029-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.216921 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved