c语言实现链表

链表是一种常见的数据结构,用于存储一系列的元素。它由一系列的节点(Node)组成,每个节点包含数据和指向下一个节点的指针。不同于数组需要连续的内存空间来存储元素,链表使用指针将节点按照某种逻辑顺序连接起来。

每个节点通常由两个部分组成:数据部分(存储元素的值)和指针部分(指向下一个节点)。链表的开头节点称为头节点(Head),而最后一个节点没有指针指向下一个节点的位置,通常使用空指针(NULL)来表示链表的结尾。

#pragma once
#define _CRT_SECURE_NO_WARNINGS
#include<stdlib.h>
#include<stdio.h>#ifdef __cplusplus
extern "C" {
#endifstruct LinkNode {int num;struct LinkNode* next;};struct LinkNode* Init_LinkList();void foreach_LinkList(struct LinkNode* pHeader);void insert_LinkList(struct LinkNode* pHeader, int oldval, int newval);void delete_LinkList(struct LinkNode* pHeader, int delval);void clear_LinkList(struct LinkNode* pHeader);void destroy_LinkList(struct  LinkNode* pHeader);void rever_LinkList(struct LinkNode* pHeader);int size_LinkList(struct LinkNode* pHeader);
#ifdef __cplusplus
}
#endif

 

#include"LinkList.h"
struct LinkNode* Init_LinkList()
{struct LinkNode* pHeader = malloc(sizeof(struct LinkNode));if (pHeader == NULL){return ;}pHeader->num = -1; pHeader->next = NULL;int val = -1;struct LinkNode* pTail = pHeader;while (1){printf("请插入数据,输入-1结束\n");scanf_s("%d",&val);if (val == -1){break;}//创建新节点struct LinkNode* newNode = malloc(sizeof(struct LinkNode));newNode->num = val;newNode->next = NULL;pTail->next = newNode;//连接pTail = newNode;}return pHeader;
}
void foreach_LinkList(struct LinkNode* pHeader)
{if (pHeader == NULL){return;}struct LinkNode* pCurrent = pHeader->next;while (pCurrent != NULL){printf("%d\n", pCurrent->num);pCurrent = pCurrent->next;}
}
void insert_LinkList(struct LinkNode* pHeader, int oldval, int newval)
{struct LinkNode* pPrev = pHeader;struct LinkNode* pCurrent = pHeader->next;while (pCurrent != NULL){if (pCurrent->num == oldval){break;}pPrev = pCurrent;pCurrent = pCurrent->next;}struct LinkNode* newNode = malloc(sizeof(struct LinkNode));newNode->num = newval;newNode->next = NULL;newNode->next = pCurrent;pPrev->next = newNode;
}void delete_LinkList(struct LinkNode* pHeader, int deval)
{if (pHeader == NULL){return;}struct LinkNode* pPrev = pHeader;struct LinkNode* pCurrent = pHeader->next;while (pCurrent != NULL){if(pCurrent->num==deval){break;}pPrev->next = pCurrent;pCurrent = pCurrent->next;}if (pCurrent == NULL){return;}pPrev->next = pCurrent->next;free(pCurrent);pCurrent = NULL;
}
void clear_LinkList(struct LinkNode* pHeader)
{if (pHeader == NULL){return;}struct LinkNode* pCurrent = pHeader->next;while (pCurrent != NULL){struct LinkNode* nextnode = pCurrent->next;free(pCurrent);pCurrent = nextnode;}pHeader->next = NULL;
}
void destroy_LinkList(struct  LinkNode* pHeader)
{if (pHeader == NULL){return;}clear_LinkList(pHeader);free(pHeader);pHeader = NULL;}
void rever_LinkList(struct LinkNode* pHeader)
{if (pHeader == NULL){return;}struct LinkNode* pPrev;struct LinkNode* pCurrent;struct LinkNode* pNext;pPrev = NULL;pNext= NULL;pCurrent = pHeader->next;while (pCurrent != NULL){pNext = pCurrent->next;pCurrent->next = pPrev;pPrev = pCurrent;pCurrent = pNext;}pHeader->next = pPrev;
}
int size_LinkList(struct LinkNode* pHeader)
{if (pHeader == NULL){return;}struct LinkNode* pCurrent = pHeader->next;int num = 0;while (pCurrent != NULL){num++;pCurrent = pCurrent->next;}return num;
}

 

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

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

相关文章

C 语言入门:如何编写 Hello World

C 语言简介 C 语言是由 Dennis Ritchie 于 1972 年在贝尔实验室创建的一种通用编程语言。尽管年代久远&#xff0c;它仍然是一款非常流行的语言。它之所以受欢迎的主要原因是它是计算机科学领域的基础语言之一。C 语言与 UNIX 紧密相连&#xff0c;因为它被用于编写 UNIX 操作…

Audio Signal (MATLAB) 代码学习1-常见问题

问题描述 使用MATLAB完成如下操作 加载音频文件,并存储到变量x中将x和一个频率为440Hz的正弦信号相加,用结果定义一个新的信号y绘制y信号的时域图,并正确定义时间轴利用Hann window(汉宁窗)从y中提取一个20ms的窗信号利用线性预测编码(阶数20)预测白化滤波器的参数。% …

讯飞星火认知大模型与软件测试结合,提升软件质量与效率

随着人工智能技术的不断发展&#xff0c;越来越多的企业开始将其应用于软件开发过程中。其中&#xff0c;讯飞星火认知大模型作为一种基于深度学习的自然语言处理技术&#xff0c;已经在语音识别、机器翻译、智能问答等领域取得了显著的成果。而在软件测试领域&#xff0c;讯飞…

设置bat工作目录

在执行bat脚本的时候&#xff0c;如果直接双击bat脚本&#xff0c;此时的工作路径一般为C:\Users\Administrator> 很多时候需要将工作路径设置为bat脚本所在的目录&#xff0c;可以在bat脚本内设置当前工作路径为bat文件所在目录&#xff0c; cd /d %~dp0cd:设置工作目录为…

【算法优选】 动态规划之路径问题——贰

文章目录 &#x1f38b;前言&#x1f332;[下降最小路径和](https://leetcode.cn/problems/minimum-path-sum/)&#x1f6a9;题目描述&#x1f6a9;算法思路&#xff1a;&#x1f6a9;代码实现 &#x1f38d;[最小路径和](https://leetcode.cn/problems/minimum-path-sum/)&…

viple与物理机器人(一):线控模拟

为了检测viple程序与物理机器人是否能顺利连接上 如果能顺利连接上&#xff0c;那么&#xff0c;可以通过内建事件从而控制物理机器人的前进、后退、左转、右转以及暂停。 如果不能连接上&#xff0c;首先&#xff0c;程序无法控制物理机器人&#xff0c;其次&#xff0c;当vip…

公交站间的距离

&#x1f388; 算法并不一定都是很难的题目&#xff0c;也有很多只是一些代码技巧&#xff0c;多进行一些算法题目的练习&#xff0c;可以帮助我们开阔解题思路&#xff0c;提升我们的逻辑思维能力&#xff0c;也可以将一些算法思维结合到业务代码的编写思考中。简而言之&#…

我的 CSDN 三周年创作纪念日:2020-12-12

本人大叔一枚&#xff0c;自1992年接触电脑&#xff0c;持续了30年的业余电脑发烧爱好者&#xff0c;2022年CSDN博客之星Top58&#xff0c;阿里云社区“乘风者计划”专家博主。自某不知名财校毕业后进入国有大行工作至今&#xff0c;先后任职于某分行信息科技部、电子银行部、金…

C语言面试之旅:掌握基础,探索深度(面试实战之单片机并行存储器扩展)

引言 在嵌入式系统和微控制器等应用中&#xff0c;存储器是至关重要的组成部分。单片机通常具有有限的内核存储器和外部接口&#xff0c;因此扩展存储器成为许多应用的必要步骤。本文将探讨单片机并行存储器扩展的各个方面。 1、单片机并行扩展总线 并行存储器扩展是一种将…

《第一行代码:Android》第三版7.4SQLite数据库存储

布局文件略过&#xff0c;就是五个按钮&#xff0c;点击按钮执行对应的功能。 Android 专门提供了一个SQLiteOpenHelper帮助类来对数据库进行创建和升级。 自己创建一个类继承自SQLiteOpenHelper,重新写onCreate()方法和onUpgrade()方法&#xff0c;分别对应创建数据库和升级…

扔掉xshell,基于 QT 实现一个串口命令行工具(带源码)

背景 xshell 带有支持串口的命令行能力&#xff0c; 可以方便的和下位机用命令进行交互&#xff0c;如下图所示&#xff1a; msh > msh > msh >version\ | / - RT - Thread Operating System/ | \ 3.1.3 build Nov 7 20232006 - 2019 Copyright by rt-thre…

this.$emit(‘update:isVisible‘, false)作用

这个写是不是很新颖&#xff0c;传父组件传值&#xff01;这是什么鬼。。。 假设你有以下逻辑业务。在A页面弹出一个组件B&#xff0c;A组件里面使用B组件&#xff0c;是否展示B组件你使用的是baselineShow变量控制&#xff01; <BaselineData :isVisible.sync"basel…

如何在Word中简洁地插入代码

如何在Word中简洁地插入代码 背景&#xff1a; ​ 最近在一写一些论文或者报告的时候&#xff0c;需要将源代码放在论文的最后&#xff0c;有一个很头疼的问题&#xff0c;如果直接把代码从编辑器复制到word中&#xff0c;就变成了下面这个样子&#xff1a; 这有点丑陋啊&…

Qt简介、C++工程文件分离、创建Qt工程、Qt的帮助文档

QT 简介 core&#xff1a;核心模块&#xff0c;非图形的接口类&#xff0c;为其它模块提供支持 gui&#xff1a;图形用户接口&#xff0c;qt5之前 widgets&#xff1a;图形界面相关的类模块 qt5之后的 database&#xff1a;数据库模块 network&#xff1a;网络模块 QT 特性 开…

Linux系统的各项命令

文章目录 Linux系统的目录结构Linux路径的描述方式Linux命令入门**什么是命令、命令行**Linux命令基础格式 ls命令入门HOME目录和工作目录ls命令的参数和选项ls命令的 -a选项ls命令的 -l选项ls命令选项的组合使用ls选项和参数的组合使用ls命令的 -h选项 目录切换相关命令&#…

多线程案例-阻塞队列

阻塞队列是什么 阻塞队列是一种特殊的队列.也遵循"先进先出"的原则 阻塞队列能是一种线程安全的数据结构,并且具有以下特性: 当队列满的时候,继续入队列就会阻塞,直到有其他线程从队列中取走元素. 当队列空的时候,继续出队列也会阻塞,直到有其他线程往队列中插入元素…

这七款网工在线画拓扑工具,绝了!

你们好&#xff0c;我的网工朋友。 画拓扑图&#xff0c;绝对是网络工程师的基操。 上次给你来了篇手把手教你绘制拓扑图的好文&#xff0c;还没看过的先去看啊&#xff1a;《网络拓扑图怎么画最好&#xff1f;》。 关于画拓扑的工具&#xff0c;那就多了&#xff0c;直接用…

数据结构与算法-D8D9队列实现及应用

队列&#xff1a;限制在两端进行插入和删除的线性表 允许进行存入操作的一端为“队尾” 允许进行删除操作的一端为“队头” 顺序队列 注意&#xff1a;front指向队头元素的位置 rear指向队尾元素的下一个位置 实现循环队列&#xff1a;(rear1)%N取余&#xff0c;为了区分空…

Connection refused: no further information

解决目录 一、报错信息二、解决方法 一、报错信息 二、解决方法 1、报错原因是开启了代理&#xff0c;像AS是绝对不能开代理的。 2、设置为No proxy&#xff0c;然后Apply再选择OK&#xff0c;重新同步。 要远离消耗你的人和事&#xff0c;不要花费任何情绪或者精力在他们身…

unity Pc获取本机Mac地址

1.此方法只能获取众多Mac中的一个 private static string GetMacAddress(){string physicalAddress "";NetworkInterface[] nice NetworkInterface.GetAllNetworkInterfaces();foreach (NetworkInterface adaper in nice){Debug.Log(adaper.Description);if (adape…