数据结构(超详细讲解!!)第十九节 块链串及串的应用

1.定义

由于串也是一种线性表,因此也可以采用链式存储。由于串的特殊性(每个元素只有一个字符),在具体实现时,每个结点既可以存放一个字符,也可以存放多个字符。每个结点称为块,整个链表称为块链结构,为了便于操作,再增加一个尾指针。块链结构可定义如下:

复制代码
#define  BLOCK --SIZE  <每个结点存放的字符个数>
typedef struct Block{
   char               ch[BLOCK#--SIZE]; 
   struct Block   *next;
} Block;
typedef struct { 
Block   *head; 
Block   *tail; 
int     length;
} BLString; 

2.串的应用:文本编辑

文本编辑程序用于源程序的输入和修改,公文书信、报刊和书籍的编辑排版等。常用的文本编辑程序有Edit、WPS、 Word等。文本编辑的实质是修改字符数据的形式和格式, 虽然各个文本编辑程序的功能不同,但基本操作是一样的, 都包括串的查找、插入和删除等。 为了编辑方便,可以用分页符和换行符将文本分为若干页,每页有若干行。我们把文本当作一个字符串,称为文本串,页是文本串的子串,行是页的子串。

我们采用堆存储结构来存储文本,同时设立页指针、行指针和字符指针,分别指向当前操作的页、行和字符,同时建立页表和行表存储每一页、每一行的起始位置和长度。

例:

假设有如下PASCAL源程序:

复制代码
FUNC max(x, y: integer): integer;
VAR z: integer;
BEGIN
   IF x>y THEN z: =x; 
   ELSE z: =y; 
   RETURN(z);
END; 
相关推荐
谙弆悕博士8 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
smj2302_7968265216 小时前
解决leetcode第3934题最短唯一子数组
数据结构·python·算法·leetcode
iiiiyu17 小时前
面向对象和集合编程题
java·开发语言·前端·数据结构·算法·编程语言
变量未定义~17 小时前
最长回文子串
数据结构·算法
代码中介商17 小时前
AVL树:自平衡二叉搜索树的奥秘
数据结构
玛卡巴卡ldf18 小时前
【LeetCode 手撕算法】(多维动态规划)不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离
java·数据结构·算法·leetcode·动态规划·力扣
被AI抢饭碗的人18 小时前
算法:数据结构
数据结构·算法
淞綰19 小时前
c语言的练习-字符串的练习-寻找最长连续字符以及出现次数
c语言·数据结构·学习·算法·c语言的练习
qq_2965532719 小时前
[特殊字符] 搜索插入位置:从O(n)到O(log n)的优雅进化
数据结构·算法·面试·分类·柔性数组
凯瑟琳.奥古斯特19 小时前
力扣3654:二维矩阵连续空位统计
数据结构·数据库·算法·职场和发展