news 2026/6/9 21:07:00

数据结构与算法

作者头像

张小明

前端开发工程师

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/6/9 20:11:53

C++ 变量作用域

局部变量局部变量在函数或代码块内部声明&#xff0c;仅在该函数或代码块内有效。生命周期从声明开始到代码块结束。例如&#xff1a;void func() {int x 10; // 局部变量cout << x; // 有效 } // cout << x; // 错误&#xff1a;x在此处不可见全局变量全局变量…

作者头像 李华
网站建设 2026/6/7 20:14:29

人类有史以来最伟大的10大壮举与天问一号

文章目录1. 人类有史以来最伟大的10大壮举&#xff08;按影响与突破排序&#xff09;2. 天问一号时间线&#xff08;含关键节点&#xff09;1. 人类有史以来最伟大的10大壮举&#xff08;按影响与突破排序&#xff09; 生命科学&#xff1a;人类基因组计划&#xff08;2003&…

作者头像 李华
网站建设 2026/6/6 11:54:20

S32DS使用一文说清:S32K GPIO外设初始化步骤

S32DS实战指南&#xff1a;从零搞懂S32K GPIO初始化全流程你有没有遇到过这样的情况——代码烧进去&#xff0c;LED就是不亮&#xff1f;按键按烂了也没反应&#xff1f;调试半天才发现&#xff0c;原来是某个时钟没开、引脚复用配错了&#xff0c;或者方向寄存器写反了。这种低…

作者头像 李华
网站建设 2026/6/9 20:12:48

一文说清STM32F4串口通信的STM32CubeMX教程配置步骤

手把手教你用STM32CubeMX配置STM32F4串口通信&#xff1a;从零开始的实战指南你有没有遇到过这种情况&#xff1f;刚焊好一块STM32F4开发板&#xff0c;想通过串口打印“Hello World”验证一下基本功能&#xff0c;结果打开串口助手却一片漆黑——没输出。反复检查代码、波特率…

作者头像 李华
网站建设 2026/6/6 17:21:46

screen指令在ARM开发板调试中的应用详解

用screen调试 ARM 开发板&#xff1a;从串口连接到多任务协同的实战指南你有没有遇到过这样的场景&#xff1f;深夜正在远程调试一块远在实验室的ARM开发板&#xff0c;系统启动卡在某个阶段。你盯着终端一行行刷出的内核日志&#xff0c;正准备进入U-Boot修改启动参数——突然…

作者头像 李华
网站建设 2026/6/9 17:43:42

一文说清STM32MP1在ARM平台上的资源分配策略

STM32MP1 的“双核心法”&#xff1a;如何让 Linux 与实时控制和平共处&#xff1f; 在嵌入式开发的世界里&#xff0c;我们常常面临一个两难选择&#xff1a; 要性能&#xff0c;还是实时性&#xff1f; 运行 Linux&#xff0c;意味着你能轻松接入网络、跑图形界面、用现成…

作者头像 李华