news 2026/4/18 9:39:40

数据结构与算法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构与算法

首先给出一些宏定义

#define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define INFEASIBLE -1 #define OVERFLOW -2 typedef int Status; typedef char ElemType;

1. 线性表的顺序存储(顺序表)

1.静态顺序表与动态顺序表

// 定义静态顺序表的最大容量 #define MAXSIZE 100 // 静态顺序表结构体 typedef struct { ElemType elem[MAXSIZE]; // 存储数据元素的数组,ElemType为char(来自之前的定义) int length; // 记录顺序表当前的实际长度(注意:length ≤ MAXSIZE) } SqList;
// 动态顺序表结构体 typedef struct { ElemType *elem; // 指向动态分配内存的指针,用于存储数据元素 int length; // 顺序表当前的实际长度 int capacity; // 顺序表当前的最大容量(已分配的内存大小) } SqList;

2.初始化顺序表

Status InitSqList(DynamicSqList *L, int initCapacity) { // 合法性校验 if (initCapacity <= 0) { return ERROR; } // 动态分配内存 L->elem = (ElemType *)malloc(initCapacity * sizeof(ElemType)); //或者L->elem = new ElemType[initCapacity] // 内存分配失败 if (L->elem == NULL) { return OVERFLOW; // OVERFLOW=-2(来自宏定义),表示内存溢出 } // 初始化参数 L->length = 0; // 初始实际长度为0 L->capacity = initCapacity; // 初始容量为指定值 return OK; }

3.向顺序表指定位置插入元素

Status InsertSqList(SqList &L, int pos, ElemType e){ // 1. 合法性校验:L不为空、pos位置合法、顺序表未满 if (L == NULL || pos < 1 || pos > L->length + 1 || L->length >= L->capacity) { return ERROR; } //2.移动元素,将pos后的元素向后移动一位 for(int i = L->length; i >= pos; i--){ L->elem[i] = L->elem[i--}; } //3.插入新元素 L->elem[pos - 1] = e; //4.更新数组长度 L->length++; return Ok; }

4.删除顺序表指定位置元素

Status DeleteSqList(SqList &L, int pos){ // 1. 合法性校验:L不为空、pos位置合法、顺序表未满 if (L == NULL || pos < 1 || pos > L->length || L->length == 0) { return ERROR; } //2.将pos后的元素向前移动一位 for(int i = pos-1; i < L->length; i++){ L->elem[i] = L->elem[i + 1}; } //3.更新数组长度 L->length--; return Ok; }

5.查找顺序表中指定元素

Status LocateSqList(SqList &L, ElemType e){ // 1. 合法性校验:L不为空 if (L == NULL || L->length == 0) { return ERROR; } //2.顺序遍历查找 for(int i = 0; i < L->length; i++){ if(L->elem[i] = e){ return i + 1; } //3.未找到指定元素 return 0; }

2.线性表的链式存储

1. 写出结构体定义

typedef struct student{ char num[8]; //学号 char num[8]; //姓名 int sore; //分数 struct student *next; //指针域 } Lnode, *LinkList;

或者一般分开写

typedef Struct student{ char num[8]; //学号 char num[8]; //姓名 int sore; //分数 } ElemType; typedef Struct Lnode{ ElemType data; //数据域 Struct Lnode *next; //指针域 } Lnode, *LinkList;

2.初始化链表

LinkList InitList(LinkList &L){ LinkList L = new Lnode; //或者 LinkList L = (LinkList)malloc(sizeof(Lnode)); if(L == NULL){ cout << "内存分配失败" << endl; return NULL: } L->next = NULL; //头结点的 指针域初始化为空 return L; }

3.判断链表是否为空

Status ListEmpty(LinkList &L){ if(L->next != NULL) return 0; else return 1; }

4.销毁单链表

Status DestoryList_L(LinkList &L){ Lnode *p; //或者LinkList p; while (L != NULL){ p = L; L = L->next; //头节点后移 delete P; } return OK; }

5.清空链表

Status ClearList(LinkList &L){ Lnode *p, *q; p = L->next; while(p){ q = p->next; delete p; p = q; } L->next = NULL; return OK; }

6. 链表表长

int Listlength(LinkList &L){ Lnode *p; p = L->next; int i = 0; while(p){ i++; p = p->next; } return 0; }

7.获取链表中某个位置的元素

Status GetElem(LinkList &L, int i, ElemType &e){ Lnode *p = L->next; int j = 1; while( p && j < i){ p = p->next; j++; } if(!p || j >i) return ERROR; e = p->data; return OK; } //或者(这个不如上一个优) Status GetElem(LinkList &L, int i, ElemType &e){ Lnode *p = L->next; if(i < 1) return ERROR; for(int j = 1; j < i && p; j++){ p = p->next; } if(!p) return ERROR; e = p->data; return OK; }

8.查找链表中的某个元素

\\返回地址 Lnode* LocateElem(LinkList &L, ElemType e){ Lnode *p = L->next; while(p->data != e && p){ p = p->next; } return p; } \\返回位置序号 int LocateElem(LinkList &L, ElemType e){ Lnode *p = L->next; int j = 1; while(p->data != e && p){ p = p->next; j++; } if(p) return j; return 0; }

9.在链表中某个位置插入元素

Status ListInsert(LinkList &L, int i, ElemType e){ int j = 0; Lnode *p = L; while(p && j < i-1){ p = p->next; j++; } if(!p || j > i-1) return ERROR; Lnode *s = new Lnode; s->next = p->next; p->next = s; return OK; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:51:18

计算机毕业设计springboot基于vue的网上订餐系统 SpringBoot+Vue智慧餐饮在线点餐平台 Vue与SpringBoot融合的云餐厅即时订餐系统

计算机毕业设计springboot基于vue的网上订餐系统ly71oso3 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。快节奏的都市生活把“吃饭”这件小事也推上了数字化快车道&#xff1a;…

作者头像 李华
网站建设 2026/4/18 6:31:23

基于ARM架构的Bootloader设计:完整指南

深入ARM架构的启动心脏&#xff1a;手把手构建可靠Bootloader你有没有遇到过这样的场景&#xff1f;板子上电&#xff0c;电源正常&#xff0c;晶振起振&#xff0c;但串口就是“哑巴”——一串乱码都没有。或者系统偶尔能启动&#xff0c;大多数时候却卡在某个阶段不动了。这类…

作者头像 李华
网站建设 2026/4/18 3:51:53

STM32CubeMX配置文件与代码生成关系图解说明

STM32CubeMX.ioc配置文件&#xff1a;从图形化设计到代码生成的“翻译中枢”你有没有过这样的经历&#xff1f;花了一整天配置STM32的时钟树、引脚复用和外设初始化&#xff0c;结果程序一下载——没反应。查了又查&#xff0c;最后发现是忘了打开某个外设的时钟门控。这在传统…

作者头像 李华
网站建设 2026/4/18 3:47:05

AI应用架构师的视角:AI驱动混合现实应用的未来趋势

AI应用架构师的视角:AI驱动混合现实应用的未来趋势 (注:实际发布时建议配上AI+MR系统架构图) 1. 引入与连接:当数字智能遇见物理世界 想象一下,2028年的一个清晨: 你戴上轻便的混合现实眼镜,AI助手立即识别出你的情绪状态,并根据你的日程和身体数据,在你视野中投射…

作者头像 李华
网站建设 2026/4/18 3:51:02

SRKDA训练阶段实现:谱回归核判别分析的核心算法详解

在非线性降维与分类任务中&#xff0c;核判别分析&#xff08;KDA&#xff09;因其能够有效捕捉数据的高维非线性结构而广受欢迎。然而&#xff0c;传统KDA需要对大规模核矩阵进行特征分解&#xff0c;计算复杂度高&#xff0c;内存消耗大&#xff0c;难以应对真实世界中的大规…

作者头像 李华