彭尼玛 发表于 2018-9-24 23:58:19

自定义的链表头插法的函数,一开始阔以运行,后面出了些乱七八糟的错误


有点懵逼,一开始运行都没问题的,然后突然就不行了,后面调试了一下发现这个有问题,是不是因为 堆 里没有空间了?
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct BOOK
{
        char name;
        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;
                while (gets_s(str, 40) != NULL&&str!='\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这时候是指向节点,所以把这个节点里的东西填满
}上面是代码,能不能帮忙看下是哪里有问题?

claws0n 发表于 2018-9-25 00:02:06

那一句是 (book *)malloc(sizeof(book)); //第二个不是指针

彭尼玛 发表于 2018-9-25 10:06:59

claws0n 发表于 2018-9-25 00:02
那一句是 (book *)malloc(sizeof(book)); //第二个不是指针

哦,对哦!感人
页: [1]
查看完整版本: 自定义的链表头插法的函数,一开始阔以运行,后面出了些乱七八糟的错误