【c语言篇】每日一题-pta-实验11-2-8 单链表结点删除

题目如下:

裁判测试程序样例:

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

struct ListNode {
    int data;
    struct ListNode *next;
};

struct ListNode *readlist();
struct ListNode *deletem( struct ListNode *L, int m );
void printlist( struct ListNode *L )
{
     struct ListNode *p = L;
     while (p) {
           printf("%d ", p->data);
           p = p->next;
     }
     printf("\n");
}

int main()
{
    int m;
    struct ListNode *L = readlist();
    scanf("%d", &m);
    L = deletem(L, m);
    printlist(L);

    return 0;
}

/* 你的代码将被嵌在这里 */

代码如下:

cs 复制代码
struct ListNode *readlist()
{
    struct ListNode *head, *p1, *p2;//创建指针变量
    int n = 0;                      //创建整型变量
    head = NULL;                    //初始化
    scanf("%d", &n);                // 读取第一个整数

    while (n != -1) // 当整数不等于 -1 时
    {
        p1 = (struct ListNode *)malloc(sizeof(struct ListNode)); // 为新节点分配内存
        p1->data = n; // 将整数值存储到新节点的 data 字段

        if (head == NULL) // 如果链表为空
        {
            head = p1; // 设头指针为 p1
            p2 = p1; // 设 p2 为 p1
        }
        else
        {
            p2->next = p1; // 在链表尾部添加新节点
            p2 = p1; // 更新指针 p2 以指向新添加的节点
        }
        scanf("%d", &n); // 再次读取一个整数
    }

    p2->next = NULL; // 将链表尾部设置为 NULL
    return head; // 返回链表头指针
}

//删除数值等于m的节点
struct ListNode *deletem(struct ListNode *L, int m)
{
    //指针L指向链表头
    struct ListNode *p1, *p2 = NULL, *a;
    p1 = L;//初始化为链表头指针
    while (p1 != NULL)//p1用于遍历链表,p2用于跟踪遍历过程中p1的前一个结点
    {
        if (p1->data == m)
        {
            if (p2 == NULL)//即p1为链表的头结点
            {
                L = p1->next;//使头指针指向p1->next
                a = p1;//用a来释放
                p1 = p1->next;
                free(a);
            }
            else//p1 不是头节点
            {
                p2->next = p1->next;//将p2->next更新为p1->next以删除当前节点p1
                a = p1;
                p1 = p1->next;
                free(a);
            }
        }
        else
        {
            p2 = p1;
            p1 = p1->next;
        }
    }
    return L;
}
相关推荐
少废话h24 分钟前
解决Flink中ApacheCommonsCLI版本冲突
开发语言·python·pycharm
天命码喽c27 分钟前
GraphRAG-2.7.0整合Milvus-2.5.1
开发语言·python·milvus·graphrag
后端小张28 分钟前
【JAVA进阶】Spring Boot 核心知识点之自动配置:原理与实战
java·开发语言·spring boot·后端·spring·spring cloud·自动配置
Mr_Xuhhh6 小时前
YAML相关
开发语言·python
咖啡の猫6 小时前
Python中的变量与数据类型
开发语言·python
前端达人6 小时前
你的App消息推送为什么石沉大海?看Service Worker源码我终于懂了
java·开发语言
汤姆yu6 小时前
基于springboot的电子政务服务管理系统
开发语言·python
全栈师6 小时前
C#中控制权限的逻辑写法
开发语言·c#
S***q1926 小时前
Rust在系统工具中的内存安全给代码上了三道保险锁。但正是这种“编译期的严苛”,换来了运行时的安心。比如这段代码:
开发语言·后端·rust
打点计时器7 小时前
matlab 解决wfdb工具使用本地数据集报错
开发语言·matlab