数据结构——串的定义及存储结构

embedded/2024/9/20 13:18:42/

串的定义

  • 串(string)——零个或多个任意字符组成的有限序列
  • 串是内容受限的线性表

串的几个术语

  • 子串:串中任意几个连续字符组成的子序列称为该串的子串(真子串是指不包含自身的所有子串)
  • 主串:包含子串的串相应地称为主串
  • 字符位置:字符在序列中的序号为该字符在串中的位置
  • 子串位置:子串第一个字符在主串中的位置
  • 空格串:由一个或多个空格组成的串  与空串不同

  •  串相等:当且仅当两个串的长度相等并且各个对应位置上的字符都相同时,这两个串才时相等的。

        串的应用非常广泛,计算机上的非数值处理的对象大部分是字符串数据,例如:文字编辑、符号处理、各种信息处理系统等等。

串的类型定义、存储结构

串的抽象类型定义
串的抽象类型定义
ADT String{
数据对象:D={ ai | ai ∈ CharacterSet,i=1,2,…,n,n≥0}
数据关系:R1={ < a(i-1),ai > | a(i-1),ai ∈ D,i=2,…,n }
基本操作:
StrAssign(&T,chars)    
// 生成一个其值等于chars的串T(chars是字符串常量)
StrCopy(&T,S)    
// 由串S复制得T
StrEmpty(S)    
// 若S为空串,返回true,否则返回false
StrCompare(S,T)    
// 若S>T,则返回值>0;若S=T,则返回值=0;若S<T,则返回值<0
StrLength(S)    
// 返回S的元素个数,称为串的长度
ClearString(&S)    
// 将S清为空串
Concat(&T,S1,S2)    
// 用T返回由S1和S2联接而成的新串
SubString(&Sub,S,pos,len)    
// 用Sub返回串S的第pos个字符起长度为len的子串
Index(S,T,pos)    
// 若主串S中存在和串T值相同的子串,则返回它在主串S中第pos个字符之后第一次出现的位置;否则函数值为0
Replace(&S,T,V)    
// 用V替换主串S中出现的所有与T相等的不重叠的子串
StrInsert(&S,pos,T)    
// 在串S的第pos个字符之前插入串T
StrDelete(&S,pos,len)    
// 从串S中删除第pos个字符起长度为len的子串
DestroyString(&S)    
// 销毁串S
}ADT String

串的存储结构

        串中元素逻辑关系与线性表的相同,串可以采用与线性表相同的存储结构。

 

串的顺序存储

        串的定长顺序存储结构,可以简单地理解为采用 “固定长度的顺序存储结构” 来存储字符串,因此限定了其底层实现只能使用静态数组。使用定长顺序存储结构存储字符串时,需结合目标字符串的长度,预先申请足够大的内存空间。

//------串的定长顺序存储结构-------
#define MAXLEN 255       //串的最大长度
typedef struct{char ch[MAXLEN+1];   //存储串的一维数组int length;          //串的当前长度
}SString; 
串的链式存储 

 想要方便,又想要提高存储密度,可以在一个结点存储多个字符,以克服缺点

 这种存储结构称为块链存储结构

//-------串的链式存储结构---------
#define CHUNKSIZE 80       //可由用户定义的块大小
typedef struct Chunk{char ch[CHUNKSIZE];struct Chunk*next;
}Chunk;
typedef struct{Chunk *head,*tail;    //串的头和尾指针int length;           //串的当前长度
}LString;                  //字符串的块链结构


http://www.ppmy.cn/embedded/114172.html

相关文章

MacOS Sonoma(14.x) 大写模式或中文输入法下的英文模式,光标下方永远会出现的CapsLock箭头Icon的去除办法

如图&#xff0c;MacOS Sonoma(14.x) 大写模式或中文输入法下的英文模式下&#xff0c;光标下方永远会出现一个CapsLock箭头Icon。此Icon挡住视野&#xff0c;还容易误触导致切换大小写状态&#xff0c;带来的收益远远小于带来的困扰。 解决办法 打开终端&#xff0c;输入以下…

阿里国际发布最新版多模态大模型Ovis,拿下开源第一

看一眼菜品图就知道怎么做、能给植物看病、能把手写英文准确翻译成中文、还能精准分析财报数据……多模态能力再次升级&#xff01;阿里国际AI团队发布了一款多模态大模型Ovis&#xff0c;在图像理解任务上不断突破极限&#xff0c;多种具体的子类任务中均达到了SOTA&#xff0…

网络安全(黑客技术)2024年三个月自学计划

&#x1f91f; 基于入门网络安全/黑客打造的&#xff1a;&#x1f449;黑客&网络安全入门&进阶学习资源包 前言 什么是网络安全 网络安全可以基于攻击和防御视角来分类&#xff0c;我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”…

电商安全新挑战:筑起数字防御长城,守护业务与数据安全

在当今这个数字化时代&#xff0c;电商行业正以前所未有的速度发展&#xff0c;大数据、人工智能等技术的融入不仅重塑了消费模式&#xff0c;更激发了行业新的增长点。然而&#xff0c;这片繁荣景象之下&#xff0c;隐藏着一个不容忽视的暗流——网络安全威胁。从数据泄露到恶…

什么是 IP 地址信誉?5 种改进方法

IP 地址声誉是营销中广泛使用的概念。它衡量 IP 地址的质量&#xff0c;这意味着您的电子邮件进入垃圾邮件或被完全阻止发送的可能性。 由于每个人都使用专用电子邮件提供商而不是直接通过 IP 地址进行通信&#xff0c;因此&#xff0c;这些服务可以跟踪和衡量发件人的行为质量…

Swift语言基础教程、Swift练手小项目、Swift知识点实例化学习

Swift Swift语言基础教程1. Swift简介2. 基本语法变量和常量数据类型字符串插值数组和字典 3. 控制流条件语句循环 4. 函数5. 类和结构体6. 枚举和错误处理枚举错误处理 案例&#xff1a;简单的计算器小项目&#xff1a;待办事项应用&#xff08;ToDo List&#xff09;功能代码…

C++类和对象(4)

1. 再探构造函数 之前我们实现构造函数时&#xff0c;初始化成员变量主要在构造函数体内赋值&#xff0c;构造函数初始化还有⼀种方 式&#xff0c;就是初始化列表&#xff0c;初始化列表的使用方式是以⼀个冒号开始&#xff0c;接着是⼀个以逗号分隔的数据成 员列表&#xf…

(11)(2.1.2) DShot ESCs(一)

文章目录 前言 1 连接ESC 2 选择DShot波特率 前言 DShot 是一种数字 ESC 协议&#xff0c;它允许快速、高分辨率的数字通信&#xff0c;可以改善飞行器控制&#xff0c;这在多旋翼和 quadplane 应用中特别有用。 DShot 是一种数字 ESC 协议&#xff0c;它允许快速、高分辨率…