主页 > 创业  > 

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

数据结构(超详细讲解!!)第十九节块链串及串的应用
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;

标签:

数据结构(超详细讲解!!)第十九节块链串及串的应用由讯客互联创业栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“数据结构(超详细讲解!!)第十九节块链串及串的应用