day19-线性表(顺序表)(链表I)

news2025/5/18 3:38:12

一、补充

  • 安装软件命令: sudo apt-get install  (软件名)
  1. 安装格式化对齐:sudo apt-get install clang-format
  2. 内存泄漏检测工具: sudo apt-get install valgrind

        编译后,使用命令         valgrind ./a.out        即可看内存是否泄露

二、 顺序表的基本操作

        表头结构是可选项,但最好在使用中加上;

#ifndef _SEQLIST_H_
#define _SEQLIST_H_

typedef struct person
{
    char name[32];
    char sex;
    int age;
    int score;
} DATATYPE;

typedef struct list
{
    DATATYPE *head;
    int tlen;
    int clen;
} SeqList;
//创建顺序表
SeqList *CreateSeqList(int len);
//销毁顺序表
int DestroySeqList(SeqList *list);
//遍历顺序表
int ShowSeqList(SeqList *list);
//尾插,在顺序表最后插入元素
int InsertTailSeqList(SeqList *list, DATATYPE *data);
//判断表是否满
int IsFullSeqList(SeqList *list);
//判断表是否为空表
int IsEmptySeqList(SeqList *list);
//按指定位置插入元素
int InsertPosSeqList(SeqList *list, DATATYPE *data, int pos);
//根据名字,查找元素
int FindSeqList(SeqList *list, char *name);
//根据名字,修改指定元素
int ModifySeqList(SeqList *list, char *old, DATATYPE *newdata);
//根据名字,删除指定元素
int DeleteSeqList(SeqList *list, char *name);
//清空表,清空表中已有元素
int ClearSeqList(SeqList *list);
//获得表中有效元素的个数
int GetSizeSeqList(SeqList *list);
//获得指定小标的元素本身
DATATYPE *GetItemSeqList(SeqList *list, int ind);
#endif

2.1 创建顺序表

SeqList *CreateSeqList(int len)
{
  SeqList *sl = malloc(sizeof(SeqList));
  if (NULL == sl)
    {
      fprintf(stderr, "CreateSeqList malloc error\n");
      return NULL;
    }

  sl->head = malloc(sizeof(DATATYPE) * len);
  if (NULL == sl->head)
    {
      fprintf(stderr, "CreateSeqList malloc2 error\n");
      return NULL;
    }
  sl->tlen = len;
  sl->clen = 0;

  return sl;
}

2.2 判断是否已满

int IsFullSeqList(SeqList *list)
{
  if (NULL == list)
    {
      fprintf(stderr, "IsFullSeqList paramter error\n");
      return 1;
    }
  return list->clen == list->tlen;
}

2.3  尾插,在顺序表最后插入元素

int InsertTailSeqList(SeqList *list, DATATYPE *data)
{
  if (IsFullSeqList(list))
    {
      fprintf(stderr, "SeqList full\n");
    }

  memcpy(&list->head[list->clen], data, sizeof(DATATYPE));
  list->clen++;
  return 0;
}

2.4  遍历顺序表

int ShowSeqList(SeqList *list)
{
  int len = GetSizeSeqList(list);
  int i = 0;
  for (i = 0; i < len; ++i)
    {
      printf("%s %c %d %d\n", list->head[i].name, list->head[i].sex,
             list->head[i].age, list->head[i].score);
    }
  return 0;
}

2.5 获得表中有效元素的个数

int GetSizeSeqList(SeqList *list) 
{ 
    return list->clen; 
}

2.6 判断表是否为空表

int IsEmptySeqList(SeqList *list) 
{ 
    return 0 == list->clen; 
}

2.7 根据名字,查找元素

int FindSeqList(SeqList *list, char *name)
{
  int i = 0, len = GetSizeSeqList(list);
  for (i = 0; i < len; ++i)
    {
      if (0 == strcmp(list->head[i].name, name))
        {
          return i;
        }
    }
  return -1;
}

 2.8 获得指定下标的元素本身

DATATYPE *GetItemSeqList(SeqList *list, int ind)
{
  if (NULL == list)
    {
      return NULL;
    }

  int len = GetSizeSeqList(list);
  if (ind < 0 || ind >= len)
    {
      return NULL;
    }

  return &list->head[ind];
}

2.9 按指定位置插入元素

int InsertPosSeqList(SeqList *list, DATATYPE *data, int pos)
{
  if (IsFullSeqList(list))
    {
      return 1;
    }
  int len = GetSizeSeqList(list);
  if (pos < 0 || pos > len)
    {
      return 1;
    }
  int i = 0;
  for (i = list->clen; i > pos; i--)
    {
      // Head[i] = head[i - 1];
      memcpy(&list->head[i], &list->head[i - 1], sizeof(DATATYPE));
    }
  memcpy(&list->head[pos], data, sizeof(DATATYPE));
  list->clen++;
  return 0;
}

2.10  根据名字,删除指定元素

int DeleteSeqList(SeqList *list, char *name)
{
  if (IsEmptySeqList(list))
    {
      return 1;
    }

  int ret = FindSeqList(list, name);
  if (-1 == ret)
    {
      printf("not find\n");
      return 1;
    }
  else
    {
      int len = GetSizeSeqList(list);
      int i;
      for (i = ret; i < len - 1; i++)
        {
          memcpy(&list->head[i], &list->head[i + 1], sizeof(DATATYPE));
        }
      list->clen--;
    }
  return 0;
}

2.11 根据名字,修改指定元素

int ModifySeqList(SeqList *list, char *old, DATATYPE *newdata)
{
  if (IsEmptySeqList(list))
    {
      return 1;
    }

  int ret = FindSeqList(list, old);
  if (-1 == ret)
    {
      printf("not find\n");
      return 1;
    }
  memcpy(&list->head[ret], newdata, sizeof(DATATYPE));
  return 0;
}

 2.12 清空表,清空表中已有元素

int ClearSeqList(SeqList *list)
{
  list->clen = 0;
  return 0;
}

2.13 销毁顺序表

int DestroySeqList(SeqList *list)
{
  if (NULL == list)
    {
      return 1;
    }
  free(list->head);
  free(list);
  return 0;
}

三、 线性表顺序存储的优点,缺点

3.1 优点

  1. 无需为表中的逻辑关系增加额外的存储空间
  2. 可以快速随机访问元素O(1)

3.2 缺点

  1. 插入,删除元素需要移动元素o(n)
  2. 无法动态存储

四、 链表(线性表的链式存储)

        目的:解决顺序存储的缺点,插入和删除,动态存储问题

  •  特点:
  1. 线性表链式存储结构的特点是一组任意的存储单位存储线性表的数据元素,存储单元可以是连续的,也可以不连续;
  2. 可以被存储在任意内存未被占用的位置上,所以前面的顺序表只需要存储数据元素信息就可以了。在链式结构中还需要一个元素存储下一个元素的地址
  3. 为了表示每个数据元素,a[i]与其直接后继数据元素a[i+1]之间的逻辑关系,                         对a[i]来说,除了存储其本身的信息外,还需要存一个指示器直接后续的信息。
  4. 我们把存储元素信息的域叫数据域,把存储直接后继位置的域叫指针域。这两部分信息组成数据元素ai的存储映像,叫结点(Node);

4.1 单向链表

  • next指针指向整个结点开始位置
  • 自定义类型不支持嵌套定义,因为不知道分配多大的内存空间;即在typedef srtuct node中,struct node next;不可取                    但*next可取
  • 内存中开辟空间,用指针去接表头结构
typedef struct
{
    char name[10];
    char sex;
    int age;
    int score;
}DATATYPE;

typedef struct _node_
{
    DATATYPE data;
    struct _node_ *next;
}LinkNode;

typedef struct
{
    LinkNode *head;
    int clen;
}LinkList;

4.1.1 创建链表

LinkList *CreateLinklist()
{
    LinkList *ll = malloc(sizeof(LinkList));
    if(NULL == ll)
    {
        fprintf(stderr, "CreateLinklist malloc");
        return NULL;
    }
    ll->head = NULL;
    ll->clen = 0;
    return ll;
}

4.1.2  判断链表是否为空

int IsEmptyLinkList(LinkList *ll)
{
    return  0 == ll->clen ;
}

4.1.3 头插法

(1)链表为空(直接将head指向newnode)

(2) 链表非空

int InsertHeadLinkList(LinkList *ll, DATATYPE *data)
{
    LinkNode *newnode = malloc(sizeof(LinkNode));
    if(NULL == newnode)
    {
        fprintf(stderr, "InsertHeadLinkList malloc");
        return 1;
    }

    memcpy(&newnode->data, data, sizeof(DATATYPE));
    newnode->next = NULL;

    if(IsEmptyLinkList(ll))
    {
        ll->head = newnode;
    }
    else
    {
        newnode->next = ll->head;
        ll->head = newnode;
    }
    ll->clen++;
    return 0;
}

 4.1.4 获得表中有效元素的个数

int GetSizeLinkList(LinkList *ll)
{
    return ll->clen;
}

4.1.5 遍历表中元素

  • 使tmp->next来进行遍历,借助循环 
int ShowLinkList(LinkList *ll)
{
    int len = GetSizeLinkList(ll);
    LinkNode *tmp = ll->head;

    int i;
    for(i = 0; i < len; ++i)
    {
        printf("%s %c %d %d \n", tmp->data.name, tmp->data.sex,tmp->data.age, tmp->data.score);
        tmp = tmp->next;
    }
    return 0;
}

4.1.6 根据名字,寻找元素

DATATYPE *FindLinkList(LinkList *ll, char *name)
{
    LinkNode *tmp = ll->head;
    while (tmp) 
    {
        if(0 == strcmp(tmp->data.name, name))
        {
            return &tmp->data;
        }
        tmp = tmp->next;
    }
    return NULL;
}

4.1.7 根据名字,删除元素

  • 通过比较tmp下一个的内容来控制,使tmp停于待删结点的前一个结点 
int DeleteLinkList(LinkList* ll, char* name)
{
  LinkNode* tmp = ll->head;
  if (IsEmptyLinkList(ll))
    {
      return 1;
    }
  if (0 == strcmp(tmp->data.name, name))
    {
      ll->head = ll->head->next;
      free(tmp);
      ll->clen--;
      return 0;
    }
  while (tmp->next)
    {
      if (0 == strcmp(tmp->next->data.name, name))
        {
            LinkNode* tmp2 = tmp->next;
          tmp->next = tmp->next->next;
          free(tmp2);
          ll->clen--;
          return 0;
        }
      tmp = tmp->next;
    }
  return 1;
}

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

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

相关文章

CSS- 2.1 实战之图文混排、表格、表单、学校官网一级导航栏

本系列可作为前端学习系列的笔记&#xff0c;代码的运行环境是在HBuilder中&#xff0c;小编会将代码复制下来&#xff0c;大家复制下来就可以练习了&#xff0c;方便大家学习。 HTML系列文章 已经收录在前端专栏&#xff0c;有需要的宝宝们可以点击前端专栏查看&#xff01; 点…

从零搭建AI工作站:Gemma3大模型本地部署+WebUI配置全套方案

文章目录 前言1. 安装Ollama2.Gemma3模型安装与运行3. 安装Open WebUI图形化界面3.1 Open WebUI安装运行3.2 添加模型3.3 多模态测试 4. 安装内网穿透工具5. 配置固定公网地址总结 前言 如今各家的AI大模型厮杀得如火如荼&#xff0c;每天都有新的突破。今天我要给大家安利一款…

贝叶斯优化Transformer融合支持向量机多变量时间序列预测,Matlab实现

贝叶斯优化Transformer融合支持向量机多变量时间序列预测&#xff0c;Matlab实现 目录 贝叶斯优化Transformer融合支持向量机多变量时间序列预测&#xff0c;Matlab实现效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.BO-TransformerSVM多变量时间序列预测&#xff0c…

C++_STL_map与set

1. 关联式容器 在初阶阶段&#xff0c;我们已经接触过STL中的部分容器&#xff0c;比如&#xff1a;vector、list、deque、 forward_list(C11)等&#xff0c;这些容器统称为序列式容器&#xff0c;因为其底层为线性序列的数据结构&#xff0c;里面 存储的是元素本身。那什么是…

项目依赖版本修改

React项目 因UI库无法兼容React19版本,故此降低React版本至18.x (为什么不升级UI库版本,因为没有最新版,而且找不到好的替代品) package.json 先修改package.json文件中你想修改的依赖版本号 "dependencies": { - "react": "^19.1.0", - "…

蚁群算法赋能生鲜配送:MATLAB 实现多约束路径优化

在生鲜农产品配送中&#xff0c;如何平衡运输效率与成本控制始终是行业难题。本文聚焦多目标路径优化&#xff0c;通过 MATLAB 实现蚁群算法&#xff0c;解决包含载重限制、时间窗约束、冷藏货损成本的复杂配送问题。代码完整复现了从数据生成到路径优化的全流程&#xff0c;助…

机器学习与人工智能:NLP分词与文本相似度分析

自然语言处理 你有没有想过&#xff0c;生成式 AI 工具或大型语言模型背后究竟发生了什么&#xff1f;自然语言处理&#xff08;NLP&#xff09;是这些工具的核心&#xff0c;它使计算机能够理解人类语言。换句话说&#xff0c;NLP 是连接人类交流和机器&#xff08;如计算机&…

记录一下seata后端数据库由mariadb10切换到mysql8遇到的SQLException问题

文章目录 前言一、问题记录二、参考帖子三、记录store.db.driverClassName 前言 记录一下seata后端数据库由mariadb10切换到mysql8遇到的SQLException问题。 一、问题记录 17:39:23.709 ERROR --- [ionPool-Create-1134013833] com.alibaba.druid.pool.DruidDataSource : …

CUDA学习笔记

CUDA入门笔记 总览 CUDA是NVIDIA公司对其GPU产品提供的一个编程模型&#xff0c;在2006年提出&#xff0c;近年随着深度学习的广泛应用&#xff0c;CUDA已成为针对加速深度学习算法的并行计算工具。 以下是维基百科的定义&#xff1a;一种专有的并行计算平台和应用程序编程接…

c++ 类的语法3

测试下默认构造函数。demo1&#xff1a; void testClass3() {class Demo { // 没显示提供默认构造函数&#xff0c;会有默认构造函数。public:int x; // 普通成员变量&#xff0c;可默认构造};Demo demo1;//cout << "demo1.x: " << demo1.x << en…

Python 之类型注解

类型注解允许开发者显式地声明变量、函数参数和返回值的类型。但是加不加注解对于程序的运行没任何影响&#xff08;是非强制的&#xff0c;且类型注解不影响运行时行为&#xff09;&#xff0c;属于 有了挺好&#xff0c;没有也行。但是大型项目按照规范添加注解的话&#xff…

【linux】Web服务—搭建nginx+ssl的加密认证web服务器

准备工作 步骤&#xff1a; 一、 新建存储网站数据文件的目录 二、创建一个该目录下的默认页面&#xff0c;index.html 三、使用算法进行加密 四、制作证书 五、编辑配置文件&#xff0c;可以选择修改主配置文件&#xff0c;但是不建议 原因如下&#xff1a; 自定义一个配置文…

基于HTTP头部字段的SQL注入:SQLi-labs第17-20关

前置知识&#xff1a;HTTP头部介绍 HTTP&#xff08;超文本传输协议&#xff09;头部&#xff08;Headers&#xff09;是客户端和服务器在通信时传递的元数据&#xff0c;用于控制请求和响应的行为、传递附加信息或定义内容类型等。它们分为请求头&#xff08;Request Headers&…

实战解析MCP-使用本地的Qwen-2.5模型-AI协议的未来?

文章目录 目录 文章目录 前言 一、MCP是什么&#xff1f; 1.1MCP定义 1.2工作原理 二、为什么要MCP&#xff1f; 2.1 打破碎片化的困局 2.2 实时双向通信&#xff0c;提升交互效率 2.3 提高安全性与数据隐私保护 三、MCP 与 LangChain 的区别 3.1 目标定位不同 3.…

RabbitMQ高级篇-MQ的可靠性

目录 MQ的可靠性 1.如何设置数据持久化 1.1.交换机持久化 1.2.队列持久化 1.3.消息持久化 2.消息持久化 队列持久化&#xff1a; 消息持久化&#xff1a; 3.非消息持久化 非持久化队列&#xff1a; 非持久化消息&#xff1a; 4.消息的存储机制 4.1持久化消息&…

fpga系列 HDL : Microchip FPGA开发软件 Libero Soc 项目仿真示例

新建项目 项目初始界面中创建或导入设计文件&#xff1a; 新建HDL文件 module test (input [3:0] a,input [3:0] b,output reg [3:0] sum,output reg carry_out );always (*) begin{carry_out, sum} a b; endendmodule点击此按钮可进行项目信息的重新…

DeepSearch:WebThinker开启AI搜索研究新纪元!

1&#xff0c;项目简介 WebThinker 是一个深度研究智能体&#xff0c;使 LRMs 能够在推理过程中自主搜索网络、导航网页&#xff0c;并撰写研究报告。这种技术的目标是革命性的&#xff1a;让用户通过简单的查询就能在互联网的海量信息中进行深度搜索、挖掘和整合&#xff0c;从…

springCloud/Alibaba常用中间件之Setinel实现熔断降级

文章目录 SpringCloud Alibaba:依赖版本补充Sentinel:1、下载-运行&#xff1a;Sentinel(1.8.6)下载sentinel&#xff1a;运行&#xff1a;Sentinel <br> 2、流控规则① 公共的测试代码以及需要使用的测试Jmeter①、流控模式1. 直接:2. 并联:3. 链路: ②、流控效果1. 快速…

Deeper and Wider Siamese Networks for Real-Time Visual Tracking

现象&#xff1a; the backbone networks used in Siamese trackers are relatively shallow, such as AlexNet , which does not fully take advantage of the capability of modern deep neural networks. direct replacement of backbones with existing powerful archite…

黑马程序员C++2024版笔记 第0章 C++入门

1.C代码的基础结构 以hello_world代码为例&#xff1a; 预处理指令 #include<iostream> using namespace std; 代码前2行是预处理指令&#xff0c;即代码编译前的准备工作。&#xff08;编译是将源代码转化为可执行程序.exe文件的过程&#xff09; 主函数 主函数是…