当前位置: 首页 > news >正文

C语言:链表插入

链表的插入分为头插入,中间插入和尾插入。

具体方法如下:

#include<stdio.h>
#include<stdlib.h>typedef struct node
{int s;struct node* pnext;
}list;list* addnode(list** pphead, list** ppend, int n)
{list* ptemp = malloc(sizeof(list));ptemp->s = n;ptemp->pnext = NULL;if (NULL == *pphead){*pphead = ptemp;*ppend = ptemp;}else{(*ppend)->pnext = ptemp;*ppend = ptemp;}
}void insertnode(list** pphead, list** ppend, list* pnode, int val)
{//头插入//新来节点的下一个指向头节点//头指针指向新来的节点(新来的节点成为新的头节点)if ((*pphead)->s == val){pnode->pnext = *pphead;*pphead = pnode;return;}//中间插入//遍历链表//找到插入位置的前一个结点//新来结点的下一个指向标记的下一个//标记的下一个指向新来的节点list* pmark = *pphead;while (pmark->pnext!= NULL){if (pmark->pnext->s == val){pnode->pnext = pmark->pnext;pmark->pnext = pnode;return;}pmark = pmark->pnext;}//尾插入//尾节点的下一个指向新来的节点//尾指针指向新来的节点(新来的节点成为新的尾节点)(*ppend)->pnext = pnode;*ppend = pnode;
}int main()
{list* phead = NULL;//定义头指针list* pend = NULL; //定义尾指针//先添加几个节点addnode(&phead, &pend, 1);addnode(&phead, &pend, 2);addnode(&phead, &pend, 3);addnode(&phead, &pend, 4);//创建一个节点list* ptep = malloc(sizeof(list));ptep->s = 7;ptep->pnext = NULL;//将创建的节点插入insertnode(&phead, &pend, ptep, 5);//遍历链表,检验是否成功插入while (phead != NULL){printf("%d\n", phead->s);phead = phead->pnext;}return 0;
}

http://www.lryc.cn/news/427922.html

相关文章:

  • xss 一些例子
  • 基于Docker compose部署Confluence 8.3.4及设置数据持久化存储的总结
  • eNSP 华为交换机生成树协议
  • flutter事件与消息通知
  • Oracle PL/SQL存储过程和函数简单示例
  • 同态加密和SEAL库的介绍(十)CKKS 参数心得 2
  • Debug-021-el-table实现分页多选的效果(切换分页,仍可以保持前一页的选中效果)
  • FPGA开发——DS18B20读取温度并且在数码管上显示
  • 电流测量分流电阻
  • MES系统:智能化排班排产的全面解决方案
  • 50道深度NLP和人工智能领域面试题+答案
  • 最小矩阵宽度(85%用例)C卷(JavaPythonC++Node.jsC语言)
  • STM32数据按字符截取与转换
  • 使用kubeadm快速部署一套K8S集群
  • 【Kotlin】在Kotlin项目中使用AspectJ
  • web实现drag拖拽布局
  • Linux网络编程—listen、accept、connect
  • logback.xml自定义标签节点
  • 探索DevExpress WinForms:.NET世界中的UI库之星
  • 零基础学习Redis(4) -- 常用数据结构介绍
  • Python实现水果忍者(开源)
  • Windows自动化3️⃣WindowsPC拽起时长问题解决方案
  • 一篇文章入门Java虚拟机(JVM)
  • vue3里面的组件实例类型(包括原生的html标签类型)
  • 谷歌正式开放Imagen 3访问权限!OpenAI的GPT-4o连续两周迎来两次更新!|AI日报
  • C语言内存操作函数
  • 深入探索 PyTorch:torch.nn.Parameter 与 torch.Tensor 的奥秘
  • 成为Python砖家(1): 在本地查询Python HTML文档
  • 深度学习基础—RMSprop算法与Adam 优化算法
  • 单片机原理及技术(六)—— 中断系统的工作原理