LeeZTao 2022-11-05 12:58 采纳率: 80%
浏览 8
已结题

leetcode707指针赋值报错

leetcode707 设计链表

img


几乎都是这个报错,看不懂什么意思
指针这样赋值有什么问题,求解答

typedef struct {
    int val;
    struct MyLinkedList* next;
}MyLinkedList;

MyLinkedList* myLinkedListCreate() {
    MyLinkedList* head = (MyLinkedList*)malloc(sizeof(MyLinkedList));
    if (head == NULL)
        exit(-1);
    head->next = NULL;
    return head;
}

int myLinkedListGet(MyLinkedList* obj, int index) {
    MyLinkedList* cur = obj->next;
    for (int i = 0; cur != NULL; i++)
    {
        if (i == index)
            return cur->val;
        else
            cur = cur->next;
    }

    return -1;
}

void myLinkedListAddAtHead(MyLinkedList* obj, int val) {
    MyLinkedList* shead = (MyLinkedList*)malloc(sizeof(MyLinkedList));
    if (!shead)
        exit(-1);
    shead->val = val;
    shead->next = obj->next;
    obj->next = shead;
}

void myLinkedListAddAtTail(MyLinkedList* obj, int val) {
    MyLinkedList* cur = obj;
    MyLinkedList* NewTail = (MyLinkedList*)malloc(sizeof(MyLinkedList));
    if (!NewTail || !cur)
        exit(-1);
    NewTail->val = val;
    NewTail->next = NULL;
    while (cur && cur->next) //
        cur = cur->next;
    cur->next = NewTail;
}

void myLinkedListAddAtIndex(MyLinkedList* obj, int index, int val) {
    if (index == 0)
    {
        myLinkedListAddAtHead(obj, val);
        return;
    }
    MyLinkedList* cur = obj->next;
    for (int i = 1; cur != NULL; i++)
    {
        if (index == i)
        {
            MyLinkedList* nNode = (MyLinkedList*)malloc(sizeof(MyLinkedList));
            if (nNode == NULL)
                eixt(-1);
            nNode->val = val;
            nNode->next = cur->next;
            cur->next = nNode;
            return;
        }
        else
            cur = cur->next;
    }
}

void myLinkedListDeleteAtIndex(MyLinkedList* obj, int index) {
    MyLinkedList* cur = obj;
    for (int i = 0; cur->next != NULL; i++)
    {
        if (index == i)
        {
            MyLinkedList* tmp = cur->next;
            if (!tmp)
            {
                tmp = NULL;
                free(tmp);
            }
            else
            {
                cur->next = tmp->next;
                free(tmp);
            }
            return;
        }
        else
            cur = cur->next;
    }
}  //

void myLinkedListFree(MyLinkedList* obj) {
    MyLinkedList* shead = (MyLinkedList*)malloc(sizeof(MyLinkedList));
    if (!shead)
        exit(-1);
    shead->next = obj;
    MyLinkedList* cur = shead;
    MyLinkedList* tmp;
    while ((tmp = cur->next))
    {
        cur->next = tmp->next;
        free(tmp);
    }
    free(shead);
    return;
}

  • 写回答

1条回答 默认 最新

  • 叶落花枯 2022-11-05 13:04
    关注

    结构体声明错了,要先有一个名字才能在结构体里面用自身的名字

    typedef struct node {
        int val;
        struct node* next;
    }MyLinkedList;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月13日
  • 已采纳回答 11月5日
  • 创建了问题 11月5日

悬赏问题

  • ¥15 【急】在线问答CNC雕刻机的电子电路与编程
  • ¥60 在mc68335芯片上移植ucos ii 的成功工程文件
  • ¥15 笔记本外接显示器正常,但是笔记本屏幕黑屏
  • ¥15 Python pandas
  • ¥15 蓝牙硬件,可以用哪几种方法控制手机点击和滑动
  • ¥15 生物医学数据分析。基础课程就v经常唱课程舅成牛逼
  • ¥15 云环境云开发云函数对接微信商户中的分账功能
  • ¥15 空间转录组CRAD遇到问题
  • ¥20 materialstudio计算氢键脚本问题
  • ¥15 有没有代做有偿主要做数据可视化部分即可(2023全国高考更省一本线理科类)