当前位置: 首页 > news >正文

数据结构与算法基础-学习-14-线性表之串

一、串的定义

由0-n个字符组成的有限序列。(n>=0)

二、串的相关术语

1、子串

串中任意个连续字符组成的子序列成为该串的子串。

2、主串

包含子串的串成为主串。

3、字符位置

字符在序列中的序号为该字符在串中的位置。

4、子串位置

子串第一个字符在主串中的位置。

5、空格串

一个或多个空格组成的串。和空串不同。

6、串相等

两个字符串的长度相等且每一位上的字符都相等。

7、空串

不存任何字符的序列。所有空串相等。

三、串的存储结构

1、顺序串

(1)顺序串结构体

#define SqStrSize 10//顺序串
typedef struct SqStr
{char StrArray[SqStrSize];int SqStrLen;
}SqStr;

2、链串

(1)链串结构体

//链串
typedef struct LinkStrNode
{char c;struct LinkStrNode* NextPtr;
}LinkStrNode,*LinkStrNodePtr;typedef struct LinkStr
{LinkStrNodePtr HeadPtr;LinkStrNodePtr TailPtr;int LinkStrLen;
}LinkStr;

(2)块链结构体

#define ChunkSize 10//块链
typedef struct ChunkNode
{char StrArray[ChunkSize];struct ChunkNode* NextPtr;
}ChunkNode,*ChunkNodePtr;typedef struct ChunkLink
{ChunkNodePtr HeadPtr;ChunkNodePtr TailPtr;int ChunkLinkLen;
}ChunkLink;

3、存储密度对比

存储密度公式:存储密度 = 串值所占的存储 ➗ 实际分配的存储。

例如存储100个字符:

(1)顺序串存储密度=100除以(100+4)≈ 0.96(int类型4个字节)

(2)链串存储密度 = 100除以((1+4)*100)= 0.2(一个节点有一个指针域,一个指针占4个字节)

(3)块链存储密度 = 100除以((10+4)*10)≈ 0.71(一个节点有一个指针域,一个指针占4个字节,假设一个数据域存储十个字符,一共10个节点可以存100个字符)

四、字符串匹配算法

字符串匹配算法可以参考之前写的文章《leecode-C语言实现-28. 找出字符串中第一个匹配项的下标》,里面有BF算法介绍和KMP算法具体实现以及个人理解。

http://www.lryc.cn/news/24649.html

相关文章:

  • Mac 快捷键
  • 【微服务】-微服务环境搭建
  • IGKBoard(imx6ull)-ADC编程MQ-2烟雾传感器采样
  • 前端二面vue面试题总结
  • 时间API在更新,传奇已经谢幕,但技术永远不死
  • SQL调优指南笔记22:Gathering Diagnostic Data with SQL Test Case Builder
  • 从0开始学python -43
  • Kafka基本原理
  • css3的重点内容
  • 《Roller: Fast and Efficient Tensor Compilation for Deep Learning》
  • 顺丰同城测试开发一面 49min答案,全文7000字,面试总结都在这里了
  • docker启动容器服务之后访问失败
  • GraalVM-云原生时代的JVM(Java)
  • 如何外网登录访问瑞友天翼应用虚拟化系统?——快解析内网端口映射方案
  • 蓝海彤翔执行副总裁张加廷接受【联播苏州】独家专访
  • iOS Airplay Screen Mirroring 同屏技术详解
  • 更新 Python 100道基础入门检测练习题【下篇】(附答案)
  • [RDMA-高级计算机网络report] Congestion Control for Large-Scale RDMA Departments
  • ROS2功能包Hello world(python)
  • 数学建模竞赛的一些心得体会
  • 什么是自动化测试?自动化测试现状怎么样?
  • CHAPTER 2 Web HA集群部署 - Heartbeat
  • 蓝桥杯每日一题:不同路径数(dfs深度优先)
  • NCRE计算机等级考试Python真题(十)
  • 【蓝桥杯嵌入式】点亮LED灯,流水灯的原理图解析与代码实现——STM32
  • RK3288-android8-es7210-阵列麦克风
  • 硬件工程师常见问题与答疑
  • 【Java】Java进阶学习笔记(一)—— 面向对象(封装)
  • jsp拆迁管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
  • CCNP350-401学习笔记(易错题合集)