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

4.3.1初阶数据结构(C语言)(无头不循环单链表)

1.完整的单链表+注释:

#pragma once
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>typedef int SLTDateType;     // 重定义数据类型typedef struct SListNode              // 定义结构体类型的节点
{SLTDateType data;struct SListNode* next;
}SListNode;extern SListNode* BuySListNode(SLTDateType x);                                        // 动态申请一个节点   extern void SListPrint(SListNode* plist);                                             // 1.单链表打印extern void SListPushBack(SListNode** pplist, SLTDateType x);                         // 2.单链表尾插extern void SListPushFront(SListNode** pplist, SLTDateType x);                        // 3.单链表的头插extern void SListPopBack(SListNode** pplist);                                         // 4.单链表的尾删extern void SListPopFront(SListNode** pplist);                                        // 5.单链表头删extern SListNode* SListFind(SListNode* plist, SLTDateType x);                         // 6.单链表查找extern void SListInsertBefore(SListNode** pplist, SListNode* pos, SLTDateType x);     // 7.单链表在pos位置之前插入xextern void SListInsertAfter(SListNode* pos, SLTDateType x);                          // 8.单链表在pos位置之后插入xextern void SListErase(SListNode** pplist, SListNode* pos);                           // 9.单链表删除pos位置的值extern void SListEraseAfter(SListNode* pos);                                          // 10.单链表删除pos位置之后的值extern void SListDestroy(SListNode** pplist);                                         // 11.单链表的销毁
#include"SList.h"SListNode* BuySListNode(SLTDateType x)     // 动态申请一个节点 
{SListNode* newnode = (SListNode*)malloc(sizeof(SListNode));if (newnode == NULL){exit(-1);}else{newnode->data = x;newnode->next = NULL;}return newnode;
}void SListPrint(SListNode* plist)     // 1.单链表打印
{SListNode* cur = plist;while (cur){printf("%d->", cur->data);cur = cur->next;}printf("NULL\n");
}void SListPushBack(SListNode** pplist, SLTDateType x)     // 2.单链表尾插
{if (*pplist == NULL)     //头插要改变指针,所以用二级指针操作{*pplist = BuySListNode(x);return;}SListNode* tail = *pplist;while (tail->next)     //找尾{tail = tail->next;}tail->next = BuySListNode(x);
}void SListPushFront(SListNode** pplist, SLTDateType x)     // 3.单链表的头插
{SListNode* newnode = BuySListNode(x);newnode->next = *pplist;*pplist = newnode;
}void SListPopBack(SListNode** pplist)     // 4.单链表的尾删
{if (*pplist == NULL)     //考虑特殊情况1{printf("表中没有数据,尾删失败!\n");return;}if ((*pplist)->next == NULL)     //考虑特殊情况2{free(*pplist);*pplist = NULL;return;}SListNode* end = *pplist;     //使用前后指针,便于删除SListNode* prev = *pplist;while (end->next != NULL){prev = end;end = end->next;}free(end);end = NULL;prev->next = NULL;
}void SListPopFront(SListNode** pplist)     // 5.单链表头删
{if (*pplist == NULL)     //考虑特殊情况{printf("表中没有数据,头删失败!\n");return;}SListNode* begin = *pplist;*pplist = begin->next;free(begin);begin = NULL;
}SListNode* SListFind(SListNode* plist, SLTDateType x)     // 6.单链表查找
{while (plist != NULL){if (plist->data == x){return plist;}plist = plist->next;}printf("没找到!\n");return NULL;
}void SListInsertBefore(SListNode** pplist, SListNode* pos, SLTDateType x)     // 7.单链表在pos位置之前插入x
{SListNode* newnode = BuySListNode(x);if (pos == *pplist)     //考虑特殊情况{newnode->next = *pplist;*pplist = newnode;return;}SListNode* prev = *pplist;while (prev->next != pos){prev = prev->next;}newnode->next = pos;prev->next = newnode;
}void SListInsertAfter(SListNode* pos, SLTDateType x)     // 8.单链表在pos位置之后插入x
{if (pos == NULL)     //考虑特殊情况{printf("pos位置错误,插入失败!\n");return;}SListNode* newnode = BuySListNode(x);newnode->next = pos->next;pos->next = newnode;
}void SListErase(SListNode** pplist, SListNode* pos)     // 9.单链表删除pos位置的值
{if (pos == NULL)     //考虑特殊情况{printf("pos位置错误,删除失败!\n");return;}if (*pplist == NULL)     //考虑特殊情况{printf("表中没有数据,头删失败!\n");return;}if (pos == *pplist)     //考虑头删情况{(*pplist) = pos->next;free(pos);return;}SListNode* prev = *pplist;while (prev->next != pos){prev = prev->next;}prev->next = pos->next;free(pos);
}void SListEraseAfter(SListNode* pos)     // 10.单链表删除pos位置之后的值
{if ((pos == NULL) || (pos->next == NULL)){printf("pos位置错误,删除失败!\n");return;}SListNode* next = pos->next;pos->next = next->next;free(next);
}void SListDestroy(SListNode** pplist)     // 11.单链表的销毁
{SListNode* cur = *pplist;while ((*pplist) != NULL){*pplist = (*pplist)->next;free(cur);cur = *pplist;}printf("销毁成功\n");
}

#include"SList.h"void test1()     //测试1
{SListNode* plist = NULL;/*SListPopBack(&plist);SListPrint(plist);SListPushBack(&plist, 1);SListPopBack(&plist);SListPrint(plist);SListPushBack(&plist, 2);SListPushBack(&plist, 3);SListPopBack(&plist);*/SListPrint(plist);SListPopFront(&plist);SListPushFront(&plist, 1);SListPopFront(&plist);SListPrint(plist);SListPushFront(&plist, 2);SListPushFront(&plist, 3);SListPopFront(&plist);SListPrint(plist);}void test2()     //测试2
{SListNode* plist = NULL;SListPushBack(&plist, 1);SListPushBack(&plist, 2);SListPushBack(&plist, 2);SListPushBack(&plist, 3);SListPushBack(&plist, 2);SListPushBack(&plist, 4);SListPushBack(&plist, 5);SListPrint(plist);SListNode* pos = SListFind(plist, 2);int i = 1;     //数字出现个数while (pos != NULL)     //找到所有指定的数字{printf("第%d次出现的地址:%p\n", i++, pos);pos = SListFind(pos->next, 2);}pos = SListFind(plist, 3);pos->data = 0;SListPrint(plist);}void test3()
{SListNode* plist = NULL;SListPushBack(&plist, 1);SListPushBack(&plist, 2);SListPushBack(&plist, 3);SListPushBack(&plist, 4);SListPushBack(&plist, 5);SListPushBack(&plist, 6);SListPushBack(&plist, 7);SListPrint(plist);/*SListNode* pos = SListFind(plist, 7);SListInsertBefore(&plist, pos, 0);SListPrint(plist);*//*SListNode* pos = SListFind(plist, 7);SListInsertAfter(pos, 0);SListPrint(plist);*//*SListNode* pos = SListFind(plist, 7);SListErase(&plist, pos);SListPrint(plist);*/SListNode* pos = SListFind(plist, 1);SListEraseAfter(pos);SListDestroy(&plist);SListPrint(plist);}void menu()     //菜单
{printf("********1.打印*****2.尾插********\n");printf("********3.头插*****4.尾删********\n");printf("********5.头删*****6.查找********\n");printf("********7.位前插***8.位后插******\n");printf("********9.位删****10.位后删******\n");printf("*******11.销毁*****0.退出********\n");
}void test()
{SListNode* plist = NULL;int input = 0;             //输入选择int x = 0;                 //输入插入的值SListNode* pos = NULL;     //地址变量enum choose{_exit,                       //0.退出_SListPrint,                 //1.单链表打印_SListPushBack,              //2.单链表的尾插_SListPushFront,             //3.单链表的头插_SListPopBack,               //4.单链表的尾删_SListPopFront,              //5.单链表头删_SListFind,                  //6.单链表查找_SListInsertBefore,          //7.单链表在pos位置之前插入x_SListInsertAfter,           //8.单链表在pos位置之后插入x_SListErase,                 //9.单链表删除pos位置的值_SListEraseAfter,            //10.单链表删除pos位置之后的值_SListDestroy                //11.单链表的销毁};do{menu();printf("请选择\n");scanf("%d", &input);switch (input){case _exit:break;case _SListPrint:SListPrint(plist);                //1.单链表打印break;case _SListPushBack:printf("请输入\n");scanf("%d", &x);SListPushBack(&plist, x);        //2.单链表的尾插break;case _SListPushFront:printf("请输入\n");scanf("%d", &x);SListPushFront(&plist, x);       //3.单链表的头插break;case _SListPopBack:SListPopBack(&plist);            //4.单链表的尾删break;case _SListPopFront:SListPopFront(&plist);           //5.单链表头删break;case _SListFind:printf("请输入\n");scanf("%d", &x);pos = SListFind(plist, x);             //6.单链表查找break;case _SListInsertBefore:printf("请输入\n");scanf("%d", &x);SListInsertBefore(&plist, pos, x);     //7.单链表在pos位置之前插入xbreak;case _SListInsertAfter:printf("请输入\n");scanf("%d", &x);SListInsertAfter(pos, x);             //8.单链表在pos位置之后插入xbreak;case _SListErase:SListErase(&plist, pos);              //9.单链表删除pos位置的值break;case _SListEraseAfter:SListEraseAfter(pos);                //10.单链表删除pos位置之后的值break;case _SListDestroy:SListDestroy(&plist);                //11.单链表的销毁break;default:printf("选项不存在,请重新输入!\n");break;}} while (input);
}int main()
{//test1();     //测试1//test2();     //测试2//test3();     //测试3test();system("pause");return 0;
}

2.练习题:

1.删除链表中等于给定值 val 的所有节点

2.反转一个单链表

3.给定一个带有头结点 head 的非空单链表,返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点

4.输入一个链表,输出该链表中倒数第k个结点 

5.将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的

6.编写代码,以给定值x为基准将链表分割成两部分,所有小于x的结点排在大于或等于x的结点之前

7.链表的回文结构 

8. 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针

9.对链表进行插入排序 

10.​​​​​​​​​​​​​​给定一个链表,每个节点包含一个额外增加的随机指针,该指针可以指向链表中的任何节点或空节点。要求返回这个链表的深度拷贝

11.给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 NULL

12.给定一个链表,判断链表中是否有环

13.输入两个链表,找出它们的第一个公共结点 

3.链表的优点:

1.按需申请空间不用了就释放空间,更合理的使用了空间。

2.头部中间插入删除数据,不需要挪动数据。

4.链表的缺点:

1.每一个数据都要存一个指针去链接后面的数据节点。

2.不支持随机访问。

相关文章:

4.3.1初阶数据结构(C语言)(无头不循环单链表)

1.完整的单链表注释&#xff1a; #pragma once #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> #include<stdlib.h>typedef int SLTDateType; // 重定义数据类型typedef struct SListNode // 定义结构体类型的节点 {SLTDateType data;str…...

一文深度解读音视频行业技术发展历程

从1948年的香农定律&#xff0c;到音视频的今天。IMMENSE、36氪&#xff5c;作者 北京时间2月28日凌晨&#xff0c;FIFA年度颁奖典礼在巴黎举行。梅西荣膺年度最佳球员&#xff0c;斯卡洛尼当选年度最佳男足主帅&#xff0c;马丁内斯荣获年度最佳男足门将&#xff01;阿根廷因…...

面向对象拓展贴

1. 类和对象的内存分配机制 1.1 分配机制  Java 内存的结构分析 栈&#xff1a; 一般存放基本数据类型(局部变量)堆&#xff1a; 存放对象(Cat cat , 数组等)方法区&#xff1a;常量池(常量&#xff0c;比如字符串)&#xff0c; 类加载信息示意图 [Cat (name, age, price)]…...

Android仿QQ未读消息拖拽粘性效果

效果图原理分析首先是在指定某个位置画一个圆出来&#xff0c;手指按到这个圆的时候再绘制一个可以根据手指位置移动的圆&#xff0c;随着手指的移动两个圆逐渐分离&#xff0c;分离的过程中两圆中间出现连接带&#xff0c;随着两圆圆心距的增大&#xff0c;半径也是根据某一比…...

Linux 打包压缩解压指令 gzip bzip2 tar

总结自鸟哥Linux私房菜 Linux压缩文件的扩展名大多是&#xff1a;“.tar, .tar.gz, .tgz, .gz, .Z, .bz2, *.xz”&#xff0c; 不同压缩文件使用了不同的算法&#xff0c;不能通用压缩或解压 常见扩展名&#xff1a; *.Z compress 程序压缩的文件&#xff1b; *.zip zip 程序…...

系统升级丨分享返佣,助力商企实现低成本高转化营销

秉承助力传统经济数字化转型的长远理念 酷雷曼VR再次在VR全景营销中发力 创新研发“分享返佣”功能 进一步拓宽商企VR全景营销渠道 助力商企搭建低成本、高传播、高转化 的VR营销体系 01、什么是“分享返佣”&#xff1f; ●“分享返佣”即“推广”返佣&#xff0c;是酷…...

机试代码模板

文章目录进制转换高精度加/乘法搜索BFSDFS树二叉树遍历图Dijkstra算法Kruskal算法动态规划最长公共子序列(LCS)最长上升子序列(LIS)KMP算法进制转换 #include <iostream> #include <string> #include <cmath> #include <iomanip> #include <algori…...

Java性能优化-垃圾回收算法-理解CMS回收器

垃圾回收算法 理解 CMS回收器 三个基本操作 1.回收新生代&#xff08;同时暂停所有的应用线程&#xff09; 2.运行并发周期来清理老年代数据 3.如果有必要则FULL GC压缩老年代 当发生新生代回收 &#xff0c; 如果老年代没有足够的空间容纳晋升的对象则执行FULL GC,所有线程停…...

Oracle11G的表空间数据文件大小限制问题处理

1.表空间数据文件容量 oracle11g的表空间数据文件容量与DB_BLOCK_SIZE有关&#xff0c;在初始建库时&#xff0c;DB_BLOCK_SIZE要根据实际需要&#xff0c;设置为 4K,8K、16K、32K、64K等几种大小&#xff0c;ORACLE的物理文件最大只允许4194304个数据块&#xff08;由操作系统…...

计算机三级|网络技术|备考指南|网络系统结构与设计的基本原则|1

一、网络系统结构与设计的基本原则宽带城域网的关键技术p1 p2 p3设计一个宽带城域网涉及“三个平台一个出口”&#xff0c;即网络平台、业务平台、管理平台和城市宽带出口。宽带城域网&#xff1a;宽带城域网划分为三个层次&#xff1a;核心层、汇聚层、接入层。核心层承担高速…...

基于 TI Sitara系列 AM64x核心板——程序自启动说明

前 言 本文主要介绍AM64x的Cortex-A53、Cortex-M4F和Cortex-R5F核心程序自启动使用说明。默认使用AM6442进行测试演示,AM6412测试步骤与之类似。 本说明文档适用开发环境如下: Windows开发环境:Windows 7 64bit、Windows 10 64bit 虚拟机:VMware15.5.5 Linux开发环境:Ubun…...

自学5个月Java找到了9K的工作,我的方式值得大家借鉴 第一部分

我是去年9月22日才正式学习Java的&#xff0c;因为在国营单位工作了4年&#xff0c;在天津一个月工资只有5000块&#xff0c;而且看不到任何晋升的希望&#xff0c;如果想要往上走&#xff0c;那背后就一定要有关系才行。而且国营单位的气氛是你干的多了&#xff0c;领导觉得你…...

微电影广告的内容突破方案

微电影作为新媒体时代背景的产物&#xff0c;深受大众的欢迎&#xff0c;同时&#xff0c;微电影广告在微电影模式环境下应运而生&#xff0c;以自己独特的传播优势&#xff0c;俘获了大量企业主的青睐&#xff0c;也获得了广大青年群体的喜爱。微电影广告欲确保可持续发展&…...

茌平区为什么越来越多的企业由请高新技术企业?山东同邦科技分享

茌平区为什么越来越多的企业由请高新技术企业?山东同邦科技分享 近年来&#xff0c;越来越多的企业开始申报高新技术企业&#xff0c;认定为国家高新技术企业能获得非常多的好处&#xff0c;那么具体都有哪些呢? 一、国际高新技术企业认定的好处: 1、财政补贴: 获得高新企业…...

谷歌优化排名怎么做出来的?谷歌排名多久做上去?

本文主要分享谷歌排名的算法机制&#xff0c;让你很容易地用更短的时间把Google的自然排名做到首页。 本文由光算创作&#xff0c;有可能会被剽窃和修改&#xff0c;我们佛系对待这种行为吧。 谷歌优化排名怎么做出来的&#xff1f; 答案是&#xff1a;持续更新原创优质内容…...

字节跳动青训营--Webpack

文章目录前言一、为什么要学习Webpack&#xff1f;二、什么是Webpack&#xff1f;1. 产生背景2. 基础概念三、使用Webpack1. 安装2. 编辑配置文件3. 执行编译命令核心流程四、如何使用Webpack流程类配置配置总览五、理解Loader六、理解插件插件钩子课外关注资料前言 此文章仅用…...

微信多媒体文件speex格式转为mp3文件格式

1、安装speex环境 wget https://ftp.osuosl.org/pub/xiph/releases/speex/speex-1.2.0.tar.gz tar -zxvf speex-1.2.0.tar.gz -C /usr/local/ cd /usr/local/speex-1.2.0/ ./configure make make install 2、配置path到/usr/lib 因为安装的speex生成的可执行文件默认在/usr…...

IAP初探

IAP(In-Application Programming)在应用编程&#xff0c;浅显易懂&#xff0c;按照字面意思即是在程序不关闭情况下&#xff0c;对应用进行再次写入程序&#xff0c;对程序的写入需要传输数据&#xff0c;而传输数据的前提是通信&#xff0c; IAP对代码进行更新可以简要分为以…...

【组织架构】中国铁路兰州局集团有限公司

1 公司简介 中国铁路兰州局集团有限公司&#xff0c;是中国国家铁路集团有限公司管理的18个铁路局集团有限公司之一&#xff0c;简称“兰局”。经过59年的发展&#xff0c;现已成为西北地区最大的交通运输企业之一&#xff0c;形成了以兰州为枢纽&#xff0c;由陇海铁路、包兰铁…...

【计算机三级网络技术】 第四篇 路由设计技术基础

文章目录一、分组转发二、路由选择1.理想的路由算法的基本特征2.路由算法的度量标准3.路由算法分类&#xff1a;4.IP路由选择与路由汇聚(重点)三、自治系统与Internet的路由选择协议1.自治系统2.路由选择协议的分类四、内部网关协议1.RIP的基本概念2.RIP的原理3.RIP的运行过程五…...

MPNet:旋转机械轻量化故障诊断模型详解python代码复现

目录 一、问题背景与挑战 二、MPNet核心架构 2.1 多分支特征融合模块(MBFM) 2.2 残差注意力金字塔模块(RAPM) 2.2.1 空间金字塔注意力(SPA) 2.2.2 金字塔残差块(PRBlock) 2.3 分类器设计 三、关键技术突破 3.1 多尺度特征融合 3.2 轻量化设计策略 3.3 抗噪声…...

手游刚开服就被攻击怎么办?如何防御DDoS?

开服初期是手游最脆弱的阶段&#xff0c;极易成为DDoS攻击的目标。一旦遭遇攻击&#xff0c;可能导致服务器瘫痪、玩家流失&#xff0c;甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案&#xff0c;帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...

在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能

下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能&#xff0c;包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...

通过Wrangler CLI在worker中创建数据库和表

官方使用文档&#xff1a;Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后&#xff0c;会在本地和远程创建数据库&#xff1a; npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库&#xff1a; 现在&#xff0c;您的Cloudfla…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件

在选煤厂、化工厂、钢铁厂等过程生产型企业&#xff0c;其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进&#xff0c;需提前预防假检、错检、漏检&#xff0c;推动智慧生产运维系统数据的流动和现场赋能应用。同时&#xff0c;…...

ssc377d修改flash分区大小

1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...

新能源汽车智慧充电桩管理方案:新能源充电桩散热问题及消防安全监管方案

随着新能源汽车的快速普及&#xff0c;充电桩作为核心配套设施&#xff0c;其安全性与可靠性备受关注。然而&#xff0c;在高温、高负荷运行环境下&#xff0c;充电桩的散热问题与消防安全隐患日益凸显&#xff0c;成为制约行业发展的关键瓶颈。 如何通过智慧化管理手段优化散…...

[Java恶补day16] 238.除自身以外数组的乘积

给你一个整数数组 nums&#xff0c;返回 数组 answer &#xff0c;其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法&#xff0c;且在 O(n) 时间复杂度…...

分布式增量爬虫实现方案

之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面&#xff0c;避免重复抓取&#xff0c;以节省资源和时间。 在分布式环境下&#xff0c;增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路&#xff1a;将增量判…...

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题

在数字化浪潮席卷全球的今天&#xff0c;软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件&#xff0c;这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下&#xff0c;实现高效测试与快速迭代&#xff1f;这一命题正考验着…...