C版数据结构:第4章,字符串存储与模式匹配详解
需积分: 9 164 浏览量
更新于2024-07-11
收藏 435KB PPT 举报
本章主要探讨了C版本数据结构中的字符串概念及其在程序设计中的应用。字符串被定义为由零个或多个字符组成的有限序列,具有明确的逻辑结构,包括非空串、空串、子串、主串以及它们的位置定义。通过字符间的比较来判断串的相等性和顺序关系。
在逻辑结构方面,非空串通常用"S=s1s2……sn"的形式表示,其中"S"是串名,双引号内的部分是串值,而si表示单个字符。串的长度指的是串中字符的数量,空串长度为0,记作"\"。
为了存储字符串,有两种常见的存储结构方案。首先,顺序存储结构分为非压缩和压缩两种方式。非压缩方式每个数组单元只存储一个字符,可能导致空间浪费;而压缩方式尝试在一个单元内存储多个字符,但可能增加算法实现的复杂性。方案1采用一个额外的变量表示实际串长度,这样数组以字符的形式存储,末尾添加一个特殊字符(如`\0`)来表示串结束,空闲单元用于扩展。方案2是在串尾附加一个特殊的终止字符,如双引号或`\0`,但这可能导致误识别,因为它也可能出现在字符串中。
此外,对于模式匹配,本章会讲解如何通过比较字符来确定两个串的关系,例如完全相等、不等或顺序上的先后。例如,通过逐个比较S1="ab12cd"、S2="ab12"和S3="ab13"中的字符,可以确定它们之间的相对顺序。
总结来说,第4章字符串关注的核心内容是字符串的定义、逻辑结构、长度计算、存储方法(包括顺序存储的不同形式)以及模式匹配算法。这些知识点是编程中处理文本数据的基础,对于理解和实现字符串处理函数、字符串搜索和替换等操作至关重要。
314 浏览量
2009-09-01 上传
355 浏览量
2022-07-04 上传
206 浏览量
161 浏览量
254 浏览量
2022-11-30 上传
昨夜星辰若似我
- 粉丝: 49
- 资源: 2万+
最新资源
- service-worker-tdc-sp-2015:Palestra和TDC SP 2015
- download_IntelliJ+IDEA+简体中文专题教程(电子版-2....rar
- OOP-LabTest-2020-Starter
- TSF-GRIP-任务
- raw, 电子表格与数据可视化之间缺失的链接.zip
- pindex:这是Pagerank-index的数据存储库
- Pictograms:象形图库的任务
- 图像质量评估:卷积神经网络可预测图像的美学和技术质量
- htmlservice测试成功.zip
- 绿色小清新植物绿叶边框PPT模板
- jupyter_notebook
- ionic-contrib-frosted-glass, iOS 7风格的离子应用可选磨砂玻璃效果.zip
- ZigBee无线传感器网络的有线通信与管理-综合文档
- logger-plugin:适用于HTTPlug的PSR-3 Logger插件
- 用于将 MIDI 轨道转换为 3D 打印机的 M300 扬声器 gcode 的 工具_HTML_代码_下载
- mobsf-ci:在ci中运行MobSF所需的全部