马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
有点懵逼,一开始运行都没问题的,然后突然就不行了,后面调试了一下发现这个有问题,是不是因为 堆 里没有空间了?#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct BOOK
{
char name[40];
struct BOOK *next;
} book;
typedef struct JIE{
book*head;
book*bp;
} Jie;
void add(Jie *p, char *str); //自定义一个 头插法 的链表函数。
int main(void)
{
Jie jie;
jie.head = NULL;
char str[40];
while (gets_s(str, 40) != NULL&&str[0]!='\0')
{
add(&jie, str);
}
jie.bp = jie.head;
while(jie.bp)
{
printf("%s\n", jie.bp->name);
jie.bp = jie.bp->next;
}
return 0;
}
void add(Jie *p, char *str)
{
book *ap;
ap = (book *)malloc(sizeof(book *)); //分配一个book结构大小的内存给ap
if (ap == NULL)
{
printf("出错了");
exit(EXIT_FAILURE);
}
if (p->head == NULL) //最开始在while函数前面,我让head指针指向了NULL
p->head = ap; //所以最开始head指针会指向第一个(ap)节点,以后就不动head指针了
else
p->bp->next = ap; //第二次开始执行内容,ap又有了个节点就让p->bp里的next指针指向ap
ap->next = NULL; //第一次也要执行,让ap->next指向NULL,为了让这个节点变成最后的节点。
p->bp = ap; //把p->bp指向ap,指向最后一个节点。
strcpy_s(p->bp->name, 40, str); //因为p->bp这时候是指向节点,所以把这个节点里的东西填满
}
上面是代码,能不能帮忙看下是哪里有问题?
那一句是 (book *)malloc(sizeof(book)); //第二个不是指针
|