博客
关于我
链表删除节点
阅读量:135 次
发布时间:2019-02-28

本文共 1766 字,大约阅读时间需要 5 分钟。

在C语言中,我们可以通过动态内存管理来操作链表。以下是实现链表操作的代码解释:

首先,我们定义了一个链表节点结构:

typedef struct LinkNode{    int num;    LinkNode* next;}Lk, * lk;

初始化链表时,我们创建一个头节点,并返回其指针:

lk initLinkNode(){    //创建头结点    lk headNode = (lk)malloc(sizeof(Lk));    //检验内存分配是否成功    if (headNode == NULL){        return NULL;    }    //初始化头结点    headNode->num = -1;    headNode->next = NULL;    //记录当前节点位置    lk currentNode = headNode;    //用户输入数值    int val = -1;    while(1){        printf("请给当前链表赋值,输入-1结束输入:\n");        scanf("%d", &val);        if(val == -1){            break;        }        //分配新节点存储输入值        lk node = (lk)malloc(sizeof(Lk));        node->num = val;        node->next = NULL;        //将新节点连接到链表末尾        currentNode->next = node;        //更新当前节点位置        currentNode = currentNode->next;    }    return headNode;}

遍历链表的实现如下:

void for_each_linkList(lk headNode){    if(headNode == NULL){        return;    }    //从第二个节点开始遍历    lk curNode = headNode->next;    while(curNode){        printf("%d\n", curNode->num);        curNode = curNode->next;    }}

删除链表节点的实现:

void delete_LinkList(lk headNode, int val){    if(headNode == NULL){        return;    }    //创建辅助指针    lk prveNode = (lk)malloc(sizeof(Lk));    lk curNode = (lk)malloc(sizeof(Lk));    prveNode = headNode;    curNode = headNode->next;    //查找需要删除的节点    while(curNode){        if(curNode->num == val){            break;        }        prveNode = curNode;        curNode = curNode->next;    }    //如果未找到节点    if(curNode == NULL){        return;    }    //删除节点    prveNode->next = curNode->next;    free(curNode);    curNode = NULL;}

主函数实现链表的操作:

int main(){    lk headNode = initLinkNode();    delete_LinkList(headNode, 20);    printf("链表遍历结果为:\n");    for_each_linkList(headNode);    return 0;}

转载地址:http://qewc.baihongyu.com/

你可能感兴趣的文章
OpenCV错误:在setSize中断言失败(s&>;=0)-尝试将图像放置在网络摄像头提要上时
查看>>
opencv面向对象设计初探
查看>>
OpenCV(1)读写图像
查看>>
OpenCV:不规则形状区域中每种颜色的像素数?
查看>>
OpenCV:概念、历史、应用场景示例、核心模块、安装配置
查看>>
OpenDaylight融合OpenStack架构分析
查看>>
OpenERP ORM 对象方法列表
查看>>
openEuler Summit 2022 成功举行,开启全场景创新新时代
查看>>
openEuler 正式开放:推动计算多样化时代的到来
查看>>
OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_openeuler切换root用户_su:拒绝权限_passwd: 鉴定令牌操作错误---国产瀚高数据库工作笔记001
查看>>
OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_踩坑_安装以后系统无法联网_启动ens33网卡---国产瀚高数据库工作笔记002
查看>>
OpenFeign 入门与实战
查看>>
OpenFeign源码学习
查看>>
OpenFeign组件声明式服务调用
查看>>
openfeign远程调用不起作用解决_使用Spring Boot的spring.factories进行注入---SpringCloud Alibaba_若依微服务框架改造---工作笔记007
查看>>
openfire开发(四)消息拦截器
查看>>
openfire源码解读之将cache和session对象移入redis以提升性能
查看>>
Openfire身份认证绕过漏洞复现+利用(CVE-2023-32315)
查看>>
OpenForest 开源项目安装与使用指南
查看>>
OpenGL glBlendFunc() 设置颜色混合 透明度叠加计算
查看>>