王道c语言ch11-单链表的新建、插入、删除例题

2024-03-18 06:44

本文主要是介绍王道c语言ch11-单链表的新建、插入、删除例题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

王道c语言ch11-单链表的新建、插入、删除例题

#include <stdio.h>
#include <stdlib.h>
#define END 33typedef int ElemType;typedef struct LNote {ElemType data;struct LNote *next;
} LNote, *LinkList;//头插法
void list_head_insert(LinkList &L) {ElemType x;L = (LinkList) malloc(sizeof(LNote));L->next = NULL;scanf("%d", &x);while (x != END) {LinkList s = (LinkList) malloc(sizeof(LNote));s->data = x;s->next = L->next;L->next = s;scanf("%d", &x);}
}//尾插法
void list_tail_insert(LinkList &L) {ElemType x;L = (LinkList) malloc(sizeof(LNote));L->next = NULL;scanf("%d", &x);LinkList s,r=L;while (x != END) {s = (LinkList) malloc(sizeof(LNote));s->data = x;r->next = s;r=s;scanf("%d", &x);}r->next=NULL;
}//打印单链表中所有结点的值
void list_print(LinkList P){P=P->next;printf("LinkList is :");while (P!=NULL){printf("%d   ",P->data);P=P->next;}printf("\n");
}//按位查找,返回结点
LinkList GetElem(LinkList L,int post){int i=0;if (post<0){ //post<0返回NULL post=0返回头指针return NULL;}while (L&&i<post){L=L->next;i++;}return L;
}//按值查找,返回结点
LinkList LocateElem(LinkList L,ElemType data){while (L){L=L->next;if(L->data == data){return L;}}return NULL;
}//往post的位置插入结点
bool InsertElem(LinkList L,int post,ElemType InsertData){LinkList ret = GetElem(L,post-1);if (ret){LinkList s=(LinkList) malloc(sizeof (LNote));s->data=InsertData;s->next=ret->next;ret->next=s;return true;} else{return false;}
}//删除结点
bool ListDelete(LinkList L,int i){  //不改变头结点,则不用加引用LinkList p= GetElem(L,i-1); //i=1,返回头指针//当i<=0,p=NUll,则LinkList q=p->next;会报错if(NULL==p){return false;}LinkList q=p->next;  //不直接q->next=q->next->next;是为了释放删掉的结点内存p->next=q->next;free(q);return true;
};int main() {LinkList L;list_tail_insert(L);bool ret = InsertElem(L,2,66);{if (ret){printf("insert is ture");} else{printf("insert is fault");}}list_print(L);LinkList search = GetElem(L,2);if(search){printf("function of GetElem return %d\n",search->data);} else{printf("function of GetElem return null\n");}LinkList getdata = LocateElem(L,2);if(getdata){printf("function of LocateElem return %d\n",getdata->data);} else{printf("function of LocateElem return null\n");}ListDelete(L,4);list_print(L);return 0;
}

clion快捷键:
alt+1 打开文件列表 ​​​
alt+7 查看函数列表
ctrl shift ± 打开/折叠所有函数

这篇关于王道c语言ch11-单链表的新建、插入、删除例题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/821501

相关文章

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

macOS无效Launchpad图标轻松删除的4 种实用方法

《macOS无效Launchpad图标轻松删除的4种实用方法》mac中不在appstore上下载的应用经常在删除后它的图标还残留在launchpad中,并且长按图标也不会出现删除符号,下面解决这个问... 在 MACOS 上,Launchpad(也就是「启动台」)是一个便捷的 App 启动工具。但有时候,应

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件