题解 | #KiKi学结构体和指针#

KiKi学结构体和指针

https://www.nowcoder.com/practice/0ab593ca56b1476eb05b1ff848fd7fcc

#include <stdio.h>
#include <stdlib.h>

// 声明插入、删除、销毁链表(内存回收)
void insert(int);
void delete (int);
void destroy(void);

// 仿构造器
struct Node* Node(int, struct Node*);
struct LinkedList* LinkedList(void);

// 链表节点
struct Node {
    int data;
    struct Node* next;
}* node;

// 链表
struct LinkedList {
    int size; // 长度
    struct Node* head; // 头结点
    struct Node* tail; // 尾结点
    void (*insert)(int); // 插入
    void (*delete)(int); // 删除
    void (*destroy)(void); // 销毁链表
}* linkedList;


int main() {
    int n;
    scanf("%d", &n);
    // 链表
    struct LinkedList* linkedList =  LinkedList();
    int data;
    for (int i = 0; i < n; i++) {
        scanf("%d", &data);
        // 插入节点
        linkedList->insert(data);
    }
    // 要删除的节点
    int del;
    scanf("%d", &del);
    linkedList->delete (del);
    // 链表长度
    printf("%d\n", linkedList->size);

    // 遍历链表
    struct Node* tmp = linkedList->head;
    while (tmp != NULL) {
        printf("%d ", tmp->data);
        tmp = tmp->next;
    }

    return 0;
}

// 类似于构造器
struct Node* Node(int data, struct Node* next) {
    node = (struct Node*)malloc(sizeof(struct Node));
    if (node == NULL) {
        perror("Node()");
        return NULL;
    }
    node->data = data;
    node->next = next;
    return node;
}

// 类似于构造器
struct LinkedList* LinkedList(void) {
    linkedList = (struct LinkedList*)malloc(sizeof(struct LinkedList)); 
    if (linkedList == NULL) {
        perror("LinkedList()");
        return NULL;
    }
    linkedList->size = 0;
    linkedList->head = NULL;
    linkedList->tail = NULL;
    linkedList->insert = insert;
    linkedList->delete = delete;
    linkedList->destroy = destroy;
    return linkedList;
}

void insert(int data) {
    struct Node* pNode = Node(data, NULL);
    if (pNode == NULL) {
        perror("insert(int)");
        return;
    }

    if (linkedList->head == NULL) {
        linkedList->head = pNode;
        linkedList->tail = linkedList->head;
    } else {
        linkedList->tail->next = pNode;
        linkedList->tail = pNode;
    }
    linkedList->size++;
}

void delete (int data) {
    struct Node* cur = linkedList->head;
    struct Node* prev = NULL;
    struct Node* del = NULL;
    while (cur) {
        if (cur->data == data) {
            del = cur;
            if (cur == linkedList->head) {
                linkedList->head = cur->next;
                cur = linkedList->head;
            } else {
                prev->next = cur->next;
                cur = cur->next;
            }
            free(del);
            linkedList->size--;
        } else {
            prev = cur;
            cur = cur->next;
        }
    }
}

void destroy(void) {
    struct Node* delNode = NULL;
    struct Node* tmp = linkedList->head;
    while (tmp != NULL) {
        delNode = tmp;
        tmp = tmp->next;
        free(delNode);
    }
    free(linkedList);
    linkedList = NULL;
}

全部评论

相关推荐

06-04 09:27
门头沟学院 Java
点赞 评论 收藏
分享
来个大佬救一下,为上投了都是石沉大海了,没实习经历的话怕秋招直接进不了面。什么实习这么难找,基本
心态爆炸了:现在正式的岗位都少,实习基本不咋招的,除了大厂,中小企业其实没那么多岗位需求,就算是有,大多都是招一两个廉价劳动力,同时,他们也会希望你一来就能干活的,没时间培训你,就让你了解公司的项目,你了解完就可以开始干活。再者是,很多低质量的实习其实用处没有那么大的。我去年也是找实习找到破防,最后去了一家深圳的小公司实习,工作对我来说很简单,甚至不如我在学校做的项目,秋招的时候,这段实习经历也并没有帮上什么忙,投递简历,依旧非常低的回复率。低回复率是常态,尤其是找实习,找不到,那就把重心放在优化自己的简历和项目,多看八股文,锻炼自己的面试能力,多看别人的面经,自己模拟面试,等秋招的时候,只要有那么寥寥几次,好好抓住那几次机会。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务