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

0531作业 链表

结果 

 

整体代码

 主要实现

/**实现* */
#include "./linklist.h"linklist* create_linklist(datatype param){linklist* node=(linklist*)malloc(sizeof(linklist));if(NULL==node){puts("节点创建失败");}node->param=param;node->pnext=NULL;puts("结点创建成功");return node;
}
//头插
void insert_head_linklist(linklist* head,datatype param){linklist* newNode=(linklist*)create_linklist(param);newNode->pnext=head->pnext;head->pnext=newNode;head->param++;
}
//尾插
void insert_last_linklist(linklist* head,datatype param){linklist* newNode=(linklist*)create_linklist(param);linklist* p=head;while(NULL!=p->pnext){p=p->pnext;}p->pnext=newNode;newNode->pnext=NULL;head->param++;
}//遍历
void foreach_linklist(linklist* head){ linklist* p=head;puts("-------遍历-------");printf("链表总长度:");while(NULL!=p->pnext){printf("%d \n",p->param);p=p->pnext;}printf("%d \n",p->param);puts("-----------------");}//卸载堆空间
void free_null(linklist** node){printf("正在卸载%d的堆空间\n",(*node)->param);free(*node);*node=NULL;puts("已卸载堆空间");
}
//尾删
void delete_last_linklist(linklist* head){if(head == NULL || head->pnext == NULL){puts("链表为空或只有头结点");return;}linklist* p=head;while(NULL!=p->pnext->pnext){p=p->pnext;}free_null(&(p->pnext));head->param--;puts("尾删成功");
}
//头删
void delete_head_linklist(linklist* head){if(head == NULL || head->pnext == NULL){puts("链表为空或只有头结点");return;}linklist* temp=head->pnext;head->pnext=head->pnext->pnext;free_null(&temp);head->param--;puts("头删成功");
}void insert_index_linklist(linklist *head, int index, datatype num)
{if(index > head->param+1 || index <= 0){return;}linklist *p = head;for(int i=0; i<index-1; i++){p = p->pnext;}linklist *temp = (linklist*)malloc(sizeof(linklist));temp->param = num;temp->pnext = p->pnext;p->pnext = temp;head->param++;puts("按位插入成功");
}
//指定位置删除节点
void delete_index_linklist(linklist *head, int index)
{if(NULL == head->pnext || NULL == head || index > head->param+1 || index <= 0){                                                    return;}linklist *p = head;for(int i=0; i<index-1; i++){p = p->pnext;}linklist *temp = (linklist*)malloc(sizeof(linklist));temp = p->pnext;p->pnext = temp->pnext;free_null(&temp);head->param--;puts("按位删除成功");
}
http://www.lryc.cn/news/364601.html

相关文章:

  • C++ STL - 容器
  • AI生成沉浸式3D世界(空间照片/视频)
  • 【Vue】异步更新 $nextTick
  • 【uCOS-III-编程指南】
  • 2004NOIP普及组真题 2. 花生采摘
  • SAP-SD-21-定义用于定价补充的定价过程
  • Android AAudio——C API创建AudioTrack(六)
  • 实验七、创建小型实验拓扑《计算机网络》
  • SqlServer2016企业版安装
  • HBase数据库面试知识点:第一部分 - 基础概念与特点(持续更新中)
  • 一个高效的go语言字符串转驼峰命名算法实现函数
  • Python中__init__方法的魔力:构建对象的基石
  • Appium安装及配置(Windows环境)
  • CANOE制造dll文件,以及应用dll文件
  • C++结合OpenCV进行图像处理与分类
  • Master-Worker 架构的灰度发布难题
  • 钢基础知识介绍
  • linux 系统监控脚本
  • K8s Pod的QoS类
  • TCP/IP协议栈
  • Vector容器详解
  • 设计模式-抽象工厂(创建型)
  • 攻防世界---web---Web_php_unserialize
  • 嵌入式学习记录
  • 使用from…import语句导入模块
  • idea mac快捷键
  • Day1——一些感想,学习计划和自我激励(不重要,跳过吧)
  • 网络安全渗透工具汇总
  • JavaScript 学习笔记 总结
  • 分布式架构与分布式理论