【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;
}
相关推荐
sheji341611 分钟前
【开题答辩全过程】以 基于Java的饮品店管理系统的实现为例,包含答辩的问题和答案
java·开发语言
暴躁小师兄数据学院14 分钟前
【WEB3.0零基础转行笔记】go编程篇-第12讲:go-zero入门实战
开发语言·笔记·golang·web3·区块链
小北方城市网19 分钟前
JavaScript 实战 —— 实现一个简易的 TodoList(适合前端入门 / 进阶)
开发语言·前端·javascript
向上_5035829122 分钟前
配置Protobuf输出Java文件或kotlin文件
android·java·开发语言·kotlin
njidf24 分钟前
C++中的观察者模式
开发语言·c++·算法
2301_8227828227 分钟前
C语言数组通关攻略!从一维到字符数组,零基础也能轻松掌握
c语言·算法·数组·编程基础·避坑技巧
艾莉丝努力练剑34 分钟前
alarm系统调用的一次性原理揭秘
linux·运维·服务器·开发语言·网络·人工智能·学习
探序基因44 分钟前
安装空间转录组分析软件-R包SPATA2的安装
开发语言·r语言
2301_822782821 小时前
C3 vs Zig:2026年,谁才是真正能“修复”C语言的救星?
c语言·zig·c3·系统级开发·语言革新
春日见1 小时前
E2E自驾规控30讲:环境搭建
开发语言·驱动开发·matlab·docker·计算机外设