4.2 串的表示和实现

举报
C语言入门到精通 发表于 2021/02/09 23:08:25 2021/02/09
【摘要】 01定长顺序存储表示 1、类似于线性表的顺序存储结构,用一组地址连续的存储单元存储串值得字符序列。2、在串的定长顺序存储结构中,按照预定义的大小,为每个定义的串变量分配一个固定长度的存储区。3、串的实际长度可在这预定义长度的范围内随意,超过预定义长度的串值则被舍去,称之为“截断”。4、对串串有两种表示方法:一是以下标为0的数组分量存放串的实际长度,二是在串值后面加一个不计入串长...

01定长顺序存储表示


1、类似于线性表的顺序存储结构,用一组地址连续的存储单元存储串值得字符序列。

2、在串的定长顺序存储结构中,按照预定义的大小,为每个定义的串变量分配一个固定长度的存储区。

3、串的实际长度可在这预定义长度的范围内随意,超过预定义长度的串值则被舍去,称之为“截断”。

4、对串串有两种表示方法:一是以下标为0的数组分量存放串的实际长度,二是在串值后面加一个不计入串长的结束标记字符,如在有的C语言中以“\0”表示串值得终结。


02堆分配存储表示


1、堆分配存储表示的特点是,扔以一组地址连续的存储单元存放串值字符序列,但它们的存储空间是在程序执行过程中动态分配而得。

2、在C语言中,存在一个称之为“堆”的自由存储区,并由C语言的动态分配函数malloc()和free()管理。

3、由于堆分配存储结构的串既有顺序存储结构的特点,处理方便,操作中对串长又没有任何限制,更显灵活,因此在串处理的应用程序中也常被选用。


03串的块链存储表示


1、和线性表的链式存储结构想类似,也可以采用链表示方式存储串值。由于串结构的特点性,结构中的每个数据元素是一个字符,则用链表存储串值时,存在一个“结点大小”的问题,即每个结点可以存放一个字符,也可以存放多个字符。

2、为了便于进行串的操作,当以链表存储串值时,除头指针外还可附设一个尾指针指示链表中的最后一个结点,并给出当前串的长度,称如此定义的串存储结构为块链结构。

C语言 | 由小到大输出两个数 mp.weixin.qq.com

文章来源: zhuanlan.zhihu.com,作者:小林C语言,版权归原作者所有,如需转载,请联系作者。

原文链接:zhuanlan.zhihu.com/p/337366486

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。