【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;
}
相关推荐
RuoZoe4 天前
重塑WPF辉煌?基于DirectX 12的现代.NET UI框架Jalium
c语言
祈安_8 天前
C语言内存函数
c语言·后端
郑州光合科技余经理9 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1239 天前
matlab画图工具
开发语言·matlab
dustcell.9 天前
haproxy七层代理
java·开发语言·前端
norlan_jame9 天前
C-PHY与D-PHY差异
c语言·开发语言
多恩Stone9 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
QQ4022054969 天前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
czy87874759 天前
除了结构体之外,C语言中还有哪些其他方式可以模拟C++的面向对象编程特性
c语言
遥遥江上月9 天前
Node.js + Stagehand + Python 部署
开发语言·python·node.js