解题思路:
该程序根据输入的操作类型进行相应的操作:

 - 当操作为0时,程序会打印双向链表中的所有元素。

 - 当操作为1时,程序会在指定位置插入一个整数。

 - 当操作为2时,程序会从指定位置删除一个整数。

使用双向链表来存储整数,每个节点包含整数值、指向前一个节点的指针和指向下一个节点的指针。


注意事项:
在 createNode函数中,需要为新节点分配内存,并将整数值赋给节点的成员变量。

在 insertNode函数中,需要根据指定的位置插入新节点,注意处理头节点和中间节点的情况。

在 deleteNode函数中,需要根据指定的位置删除节点,注意处理头节点和中间节点的情况。

在 printList函数中,需要遍历链表并打印每个节点的整数值。


参考代码:

#include <stdio.h>

#include <stdlib.h>


// 定义双向链表节点结构体

typedef struct Node {

    int data;

    struct Node* prev;

    struct Node* next;

} Node;


// 函数声明

Node* createNode(int data);

Node* insertNode(Node* head, int position, int data);

Node* deleteNode(Node* head, int position);

void printList(Node* head);


int main() {

    Node* head = NULL;

    int operation, position, data;


    while (scanf("%d", &operation) != EOF) {

        if (operation == 0) {

            // 输出双向链表中的所有元素

            printList(head);

        } else if (operation == 1) {

            // 插入一个整数到双向链表中

            scanf("%d %d", &position, &data);

            head = insertNode(head, position, data);

        } else if (operation == 2) {

            // 从双向链表中删除一个整数

            scanf("%d", &position);

            head = deleteNode(head, position);

        }

    }


    // 释放链表内存

    Node* current = head;

    while (current != NULL) {

        Node* temp = current;

        current = current->next;

        free(temp);

    }


    return 0;

}


// 创建一个双向链表节点

Node* createNode(int data) {

    Node* newNode = (Node*)malloc(sizeof(Node));

    newNode->data = data;

    newNode->prev = NULL;

    newNode->next = NULL;

    return newNode;

}


// 在指定位置插入一个整数到双向链表中

Node* insertNode(Node* head, int position, int data) {

    Node* newNode = createNode(data);


    if (head == NULL) {

        // 空链表,直接将新节点作为头节点

        head = newNode;

    } else if (position == 1) {

        // 在头部插入新节点

        newNode->next = head;

        head->prev = newNode;

        head = newNode;

    } else {

        // 在指定位置插入新节点

        Node* current = head;

        int count = 1;


        while (count < position - 1 && current->next != NULL) {

            current = current->next;

            count++;

        }


        if (count == position - 1) {

            newNode->next = current->next;

            newNode->prev = current;

            if (current->next != NULL) {

                current->next->prev = newNode;

            }

            current->next = newNode;

        }

    }


    return head;

}


// 从指定位置删除一个整数

Node* deleteNode(Node* head, int position) {

    if (head == NULL) {

        // 空链表,无需删除

        return head;

    }


    if (position == 1) {

        // 删除头节点

        Node* temp = head;

        head = head->next;

        if (head != NULL) {

            head->prev = NULL;

        }

        free(temp);

    } else {

        // 删除指定位置节点

        Node* current = head;

        int count = 1;


        while (count < position && current != NULL) {

            current = current->next;

            count++;

        }


        if (count == position && current != NULL) {

            current->prev->next = current->next;

            if (current->next != NULL) {

                current->next->prev = current->prev;

            }

            free(current);

        }

    }


    return head;

}


// 打印双向链表中的所有元素

void printList(Node* head) {

    Node* current = head;

    while (current != NULL) {

        printf("%d ", current->data);

        current = current->next;

    }

    printf("\n");

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论