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

数据结构---单向链表

 

单向链表 

//链表的创建
Link_t *create_link()
{Link_t *plink = malloc(sizeof(Link_t));if(NULL == plink){perror("fail plink");return NULL;}plink->phead = NULL;plink->clen = 0;return plink;
}
//头插
int push_link_head(Link_t *plink, DataType data)
{Link_Node_t *pnode = malloc(sizeof(Link_Node_t));if(NULL == pnode){perror("fail malloc");return -1;}pnode->data = data;pnode->pnext = NULL;pnode->pnext = plink->phead;plink->phead = pnode;plink->clen++;return 0;
}
//尾插
int push_link_end(Link_t *plink, DataType data)
{Link_Node_t *p = plink->phead;if(p == NULL){push_link_head(plink, data);}else{while(p->pnext != NULL){p = p->pnext;}Link_Node_t *pnode = malloc(sizeof(Link_Node_t));if(NULL == pnode){perror("fail pnode");return -1;}p->pnext = pnode;pnode->pnext = NULL;pnode->data = data;plink->clen++;}return 0;
}
//头删
int push_head_pop(Link_t *plink)
{Link_Node_t *p = plink->phead;if(p == NULL){return 0;}else{plink->phead = p->pnext;free(p);}plink->clen--;return 1;
}
//尾删
int push_end_pop(Link_t *plink)
{Link_Node_t *p = plink->phead;if(p == NULL){return 0;}else if(p->pnext == NULL){push_head_pop(plink);}else{while(p->pnext->pnext != NULL){p = p->pnext;}free(p->pnext);p->pnext = NULL;plink->clen--;}return 1;
}

 在进行排序时,一次遍历结束指针指到了结尾,要重新把指针归到头节点,否则排序不成功。

//排序
void push_sort(Link_t *plink)
{if(1 == plink->clen || plink->phead == NULL){return;}Link_Node_t *pinsert = NULL;Link_Node_t *ptmp = plink->phead->pnext;plink->phead->pnext = NULL;while(ptmp != NULL){Link_Node_t *p = plink->phead;pinsert = ptmp;ptmp = ptmp->pnext;if(p->data > pinsert->data){pinsert->pnext = plink->phead;plink->phead = pinsert;}else{while(p->pnext != NULL && p->pnext->data < pinsert->data){p = p->pnext;}pinsert->pnext = p->pnext;p->pnext = pinsert;}}
}

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

相关文章:

  • 基于STM32设计的ECG+PPG人体参数测量系统(华为云IOT)(217)
  • SpringBoot教程(十五) | SpringBoot集成RabbitMq(死信队列、延迟队列)
  • Dubbo依赖包
  • webGIS后端程序员学习路线
  • OpenCV绘图函数(15)图像上绘制矩形函数 rectangle()的使用
  • 从零开始,认识游戏设计师(4)体验源于设计师②
  • 周末总结(2024/09/07)
  • MySQL数据库的SQL注入漏洞解析
  • Redis进阶(七):分布式锁
  • Python 中考虑 concurrent.futures 实现真正的并行计算
  • 【C++多线程编程】 线程安全与对象生命周期管理
  • 【系统架构设计师-2024年-上半年】综合知识-答案及详解
  • MATLAB 中的对数计算
  • 详解 HTTPS 与 TLS证书链校验
  • 新手做短视频素材在哪里找?做短视频素材工具教程网站有哪些?
  • 【html】编辑器、基础、属性、标题、段落、格式化、 连接、头部、CSS、图像
  • 算法【洪水填充】
  • PostgreSQL的repmgr工具介绍
  • 面试官:synchronized的锁升级过程是怎样的?
  • Linux中的时间
  • 用Boot写mybatis的增删改查
  • 电脑主机内存
  • 文件操作与隐写
  • SQLException: No Suitable Driver Found - 完美解决方法详解
  • pycharm破解教程
  • 如何使用 ef core 的 code first(fluent api)模式实现自定义类型转换器?
  • MapSet之相关概念
  • 【大数据】浅谈Pyecharts:数据可视化的强大工具
  • [深度学习][LLM]:浮点数怎么表示,什么是混合精度训练?
  • openssl双向认证自签名证书生成