C语言强化-3.单链表的新建、查找

与408的关联:1. 链表出了很多大题。 2. 任何数据结构,主要进行的操作就是增删改查。

头插法新建链表的实战

流程图

代码

#include <stdio.h>
#include <stdlib.h>typedef int ElemType;
typedef struct LNode{ElemType data;//数据域struct LNode *next;
}LNode,*LinkList;
//LNode* 是结构体指针,和LinkList完全等价的
void list_head_insert(LinkList &L){L = (LinkList)malloc(sizeof(LNode));//申请头结点空间,头指针指向头结点L -> next = NULL;ElemType x;scanf("%d",&x);LNode *s;//s用来指向申请的新结点while (x != 9999){s = (LinkList)malloc(sizeof(LNode));s -> data = x;s->next = L->next;//s的next结点指向原本链表的第一个结点L->next = s;//头结点的next,指向新结点scanf("%d",&x);}
}void print_list(LinkList L){L = L -> next;while(L != NULL){printf("%3d",L->data);L = L->next;}printf("\n");
}//头插法来新建链表
int main() {LinkList L;//链表头指针,是结构体指针类型list_head_insert(L);//输入数据可以为3 4 5 6 7 9999,头插法新建链表print_list(L);//链表打印return 0;
}
//输出
3 4 5 6 7 99997  6  5  4  3

尾插法新建链表的实战

流程图

尾插法的特点是:始终让尾指针r指向链表的尾部

代码

//尾插法新建链表
void list_tail_insert(LinkList &L){L = (LinkList)malloc(sizeof(LNode));//申请头结点空间,头指针指向头结点L -> next = NULL;ElemType x;scanf("%d",&x);LNode *s,*r =L;//s用来指向申请的新结点,r始终指向链表尾部while (x != 9999){s = (LinkList)malloc(sizeof(LNode));//为新结点申请存储空间s->data = x;r->next = s;//新结点给尾结点的next指针r=s;//r要指向新的尾部scanf("%d",&x);}r->next=NULL;//让尾结点的next为NULL
}

链表按位置查找及按值查找实战

流程图

按位置要注意判断:❗查找位置是否合法!

代码

#include <stdio.h>
#include <stdlib.h>typedef int ElemType;
typedef struct LNode{ElemType data;//数据域struct LNode *next;
}LNode,*LinkList;
void list_tail_insert(LinkList &L){L = (LinkList)malloc(sizeof(LNode));//申请头结点空间,头指针指向头结点L -> next = NULL;ElemType x;scanf("%d",&x);LNode *s,*r =L;//s用来指向申请的新结点,r始终指向链表尾部while (x != 9999){s = (LinkList)malloc(sizeof(LNode));//为新结点申请存储空间s->data = x;r->next = s;//新结点给尾结点的next指针r=s;//r要指向新的尾部scanf("%d",&x);}r->next=NULL;//让尾结点的next为NULL
}
void print_list(LinkList L){L = L -> next;while(L != NULL){printf("%3d",L->data);L = L->next;}printf("\n");
}//按位置查找
LinkList GetElem(LinkList L,int SearchPos){int i = 0;if(SearchPos<0){return  NULL;}while(L && i < SearchPos){L = L -> next;i++;}return L;
}//按值查找
LinkList LocateElem(LinkList L,ElemType SearchVal){while(L){if(L->data == SearchVal){//如果找到对应的值,就返回那个结点的地址return L;}L = L ->next;}return NULL;
}int main() {LinkList L,search;//链表头指针,是结构体指针类型;search用来存储拿到的某一个结点list_tail_insert(L);print_list(L);//链表打印//按位置查找search = GetElem(L,2);if(search != NULL){printf("Succeeded in searching by serial number\n");printf("%d\n",search->data);}//按值查找search = LocateElem(L,6);if(search != NULL){printf("Search by value succeeded\n");printf("%d\n",search->data);}return 0;
}
//输出
2 3 4 5 6 99992  3  4  5  6
Succeeded in searching by serial number
3
Search by value succeeded
6

往第i个位置插入元素实战

流程图

把新结点插入到第i个位置,策略是调用之前的GetElem函数,拿到i-1位置的元素地址。

代码

//往第i个位置插入元素
bool ListFrontInsert(LinkList L,int i,ElemType InsertVal){LinkList p = GetElem(L,i-1);if(NULL == p){return false;}LinkList q;q = (LinkList)malloc(sizeof(LNode));q -> data = InsertVal;q ->next = p -> next;p -> next = q;return true;
}int main() {LinkList L,search;//链表头指针,是结构体指针类型;search用来存储拿到的某一个结点list_tail_insert(L);print_list(L);//链表打印ListFrontInsert(L,2,99);//新结点插入第i个位置print_list(L);return 0;
}
//输出
3 4 5 6 7 99993  4  5  6  73 99  4  5  6  7

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/385087.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

视频生成【文章汇总】SVD, Sora, Latte, VideoCrafter12, DiT...

视频生成【文章汇总】SVD, Sora, Latte, VideoCrafter12, DiT... 数据集指标 【arXiv 2024】MiraData: A Large-Scale Video Dataset with Long Durations and Structured Captions【CVPR 2024】VBench : Comprehensive Benchmark Suite for Video Generative Models【arxiv 20…

微信小程序支付流程

前端需要做的事情&#xff1a; 生成平台订单&#xff1a;前端调用接口&#xff0c;向后端传递购买的商品信息、收货人信息&#xff0c;&#xff08;后端生成平台订单&#xff0c;返回订单编号&#xff09;获取预付单信息&#xff1a;将订单编号发送给后端后&#xff0c;&#x…

我在Vscode学Java泛型(泛型设计、擦除、通配符)

Java泛型 一、泛型 Generics的意义1.1 在没有泛型的时候&#xff0c;集合如何存储数据1.2 引入泛型的好处1.3 注意事项1.3.1 泛型不支持基本数据类型1.3.2 当泛型指定类型&#xff0c;传递数据时可传入该类及其子类类型1.3.3 如果不写泛型&#xff0c;类型默认是Object 二、泛型…

.net 连接达梦数据库开发环境部署

.net 开发环境部署 1. 环境准备 测试工具 Visual Studio2022 数据库版本 dm8 2. 搭建过程 1 &#xff09;创建新项目 2 &#xff09;选择创建空项目 3 &#xff09;配置新项目 4 &#xff09;右键 DM1 新建一个项 5 &#xff09;加 载 驱 动 &#xff0c; 新 建 …

SQL labs-SQL注入(五,使用sqlmap进行cookie注入)

本文仅作为学习参考使用&#xff0c;本文作者对任何使用本文进行渗透攻击破坏不负任何责任。 引言&#xff1a; Cookie 是一些数据, 存储于你电脑上的文本文件中。当 web 服务器向浏览器发送 web 页面时&#xff0c;在连接关闭后&#xff0c;服务端不会记录用户的信息。Cookie…

加速决策过程:企业级爬虫平台的实时数据分析

摘要 在当今数据驱动的商业环境中&#xff0c;企业如何才能在海量信息中迅速做出精准决策&#xff1f;本文将探讨企业级爬虫平台如何通过实时数据分析加速决策过程&#xff0c;实现数据到决策的无缝衔接。我们聚焦于技术如何赋能企业&#xff0c;提升数据处理效率&#xff0c;…

RK3568 Linux 平台开发系列讲解(内核入门篇):从内核的角度看外设芯片的驱动

在嵌入式 Linux 开发中,外设芯片的驱动是实现操作系统与硬件之间交互的关键环节。对于 RK3568 这样的处理器平台,理解如何从内核的角度构建和管理外设芯片的驱动程序至关重要。 1. 外设驱动的基础概念 外设驱动(Device Driver)是操作系统与硬件设备之间的桥梁。它负责控…

mysql面试(六)

前言 本章节详细讲解了一下mysql执行计划相关的属性释义&#xff0c;以及不同sql所出现的不同效果 执行计划 一条查询语句经过mysql查询优化器的各种基于成本和各种规则优化之后&#xff0c;会生成一个所谓的 执行计划&#xff0c;这个执行计划展示了这条查询语句具体查询方…

【计算机网络】TCP协议详解

欢迎来到 破晓的历程的 博客 ⛺️不负时光&#xff0c;不负己✈️ 文章目录 1、引言2、udp和tcp协议的异同3、tcp服务器3.1、接口认识3.2、服务器设计 4、tcp客户端4.1、客户端设计4.2、说明 5、再研Tcp服务端5.1、多进程版5.2、多线程版 5、守护进程化5.1、什么是守护进程5.2…

基于 HTML+ECharts 实现智慧安防数据可视化大屏(含源码)

构建智慧安防数据可视化大屏&#xff1a;基于 HTML 和 ECharts 的实现 随着科技的不断进步&#xff0c;智慧安防系统已经成为保障公共安全的重要工具。通过数据可视化&#xff0c;安防管理人员可以实时监控关键区域的安全状况、人员流动以及设备状态&#xff0c;从而提高应急响…

【element ui】input输入控件绑定粘贴事件,从 Excel 复制的数据粘贴到输入框(el-input)时自动转换为逗号分隔的数据

目录 1、需求2、实现思路:3、控件绑定粘贴事件事件修饰符说明: 4、代码实现&#x1f680;写在最后 1、需求 在 Vue 2 和 Element UI 中&#xff0c;要实现从 Excel 复制空格分隔的数据&#xff0c;并在粘贴到输入框&#xff08;el-input&#xff09;时自动转换为逗号分隔的数据…

代码随想录训练第三十天|01背包理论基础、01背包、LeetCode416.分割等和子集

文章目录 01背包理论基础01背包二维dp数组01背包一维dp数组(滚动数组) 416.分割等和子集思路 01背包理论基础 背包问题的理论基础重中之重是01背包&#xff0c;一定要理解透&#xff01; leetcode上没有纯01背包的问题&#xff0c;都是01背包应用方面的题目&#xff0c;也就是…

领略诗词之妙,发觉生活之美。

文章目录 引言落霞与孤鹜齐飞,秋水共长天一色。野渡无人舟自横。吹灭读书灯,一身都是月。我醉欲眠卿且去,明朝有意抱琴来。赌书消得泼茶香,当时只道是寻常。月上柳梢头,人约黄昏后。最是人间留不住,朱颜辞镜花辞树。山中何事?松花酿酒,春水煎茶。似此星辰非昨夜,为谁风…

Github 2024-07-26开源项目日报 Top10

根据Github Trendings的统计,今日(2024-07-26统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Java项目2TypeScript项目2C++项目2HTML项目1Python项目1C#项目1Lua项目1JavaScript项目1Vue项目1C项目1免费编程学习平台:freeCodeCamp.org 创…

vuepress搭建个人文档

vuepress搭建个人文档 文章目录 vuepress搭建个人文档前言一、VuePress了解二、vuepress-reco主题个人博客搭建三、vuepress博客部署四、vuepress后续补充 总结 vuepress搭建个人文档 所属目录&#xff1a;项目研究创建时间&#xff1a;2024/7/23作者&#xff1a;星云<Xing…

c++语言学习注意事项

当学习C语言时&#xff0c;有几个重要的注意事项可以帮助初学者更有效地掌握这门强大的编程语言&#xff1a; 1. 理解基本概念和语法 C 是一门复杂且功能强大的编程语言&#xff0c;因此理解其基本概念和语法至关重要。初学者应该重点掌握以下几个方面&#xff1a; 基本语法和…

WordPress原创插件:自定义文章标题颜色

插件设置截图 文章编辑时&#xff0c;右边会出现一个标题颜色设置&#xff0c;可以设置为任何颜色 更新记录&#xff1a;从输入颜色css代码&#xff0c;改为颜色选择器&#xff0c;更方便&#xff01; 插件免费下载 https://download.csdn.net/download/huayula/89585192…

网络基础之(11)优秀学习资料

网络基础之(11)优秀学习资料 Author&#xff1a;Once Day Date: 2024年7月27日 漫漫长路&#xff0c;有人对你笑过嘛… 全系列文档可参考专栏&#xff1a;通信网络技术_Once-Day的博客-CSDN博客。 参考文档&#xff1a; 网络工程初学者的学习方法及成长之路&#xff08;红…

02、爬虫数据解析-Re解析

数据解析的目的是不拿到页面的全部内容&#xff0c;只拿到部分我们想要的内容内容。 Re解析就是正则解析&#xff0c;效率高准确性高。学习本节内容前需要学会基础的正则表达式。 一、正则匹配规则 1、常用元字符 . 匹配除换行符以外的字符 \w 匹配字母或数字或下划…