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

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

1.定义

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

define  BLOCK --SIZE  <每个结点存放的字符个数>
typedef struct Block{
   char               chBLOCK#--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; 

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6