存储过程 while is null_4.2 串的存储实现(2)

返回目录:

Chilan Yu:《数据结构》目录链接​zhuanlan.zhihu.com
e4dd86f54eef9aca57554d242ee40d4c.png

4.2.2 堆串

字符串包括串名串值两部分,而串值采用堆串存储方式存储,串名用符号表存储。

堆串存储方式:这种存储方法以一组地址连续的存储单元存放串的字符序列,但它们的存储空间是在程序执行过程中动态分配的。系统将一个地址连续、容量很大的存储空间作为字符串的可用空间,每当建立一个新串时,系统就从这个空间中分配一个大小和字符串长度相同的空间存储新串的串值。

串名符号表:所有串名的存储映像构成一个符号表。借助此结构可以在串名和串值之间建立一个对应关系,称为串名的存储映像。

堆串的存储映象示例: a='a program',b='string ',c='process',free=23(注意:b中string后有一个空格)

ada01da4f11f0c0988a88c3c5d38cc09.png

堆串定义:

/*堆串的定义*/
typedef struct{char * ch;//位置指针(指示串的起始地址)int len;//串的长度
}HString;

1. 堆串赋值函数

/*堆串赋值函数*/
void StrAssign(HString * s,char * tval){//将字符串常量tval的值赋给堆串sint len,i=0;if(s->ch!=NULL) free(s->ch);//如果堆串的起始位置指针有所指,则释放空间while(tval[i]!='0') ++i;//遍历一遍字符串常量tval得到其长度len = i;if(len){//如果字符串常量tval长度不为0s->ch = (char *)malloc(len);//开辟空间for(i=0;i<len;++i) s->ch[i] = tval[i];//每个字符一一赋值}else s->ch = NULL;//否则把堆串的起始位置指针指向NULLs->len = len;//修改堆串长度
}

2. 堆串插入函数

/*堆串插入函数*/
void StrInsert(HString * s,int pos,HString * t){//在串s中下标为pos的字符之前插入串tint i;char * temp;if(pos<0 || pos>s->len || s->len==0) return ;//插入位置不合法temp = (char *)malloc(s->len+t->len);for(i=0;i<pos;++i) temp[i] = s->ch[i];//先把s中在pos之前的字符复制到temp中for(i=0;i<t->len;++i) temp[i+pos] = t->ch[i];//再把t插入for(i=pos;i<s->len;++i) temp[i+t->len] = s->ch[i];//最后把s中在pos之后的字符复制到temp中s->len += t->len;//更新长度free(s->ch);//释放原来所指位置s->ch = temp;//把起始位置指针指向新的位置
}

3. 堆串删除函数

/*堆串删除函数*/
void StrDelete(HString * s,int pos,int len){//在串s中删除从序号pos起len个字符int i;char * temp;if(pos<0 || pos>(s->len-len)) return ;temp = (char *)malloc(s->len-len);for(i=0;i<pos;++i) temp[i] = s->ch[i];for(i=pos;i<s->len-len;i++) temp[i] = s->ch[i+len];s->len = s->len-len;free(s->ch);s->ch = temp;
}

4. 堆串复制函数

/*堆串复制函数*/
void StrCopy(HString * s,HString t){//将串t的值复制到串s中int i;s->ch = (char *)malloc(t.len);for(i=0;i<t.len;++i)s->ch[i] = t.ch[i];s->len = t.len;
}

5. 判空函数

/*判空函数*/
int StrEmpty(HString s){//若串s为空(即串长为0),则返回1,否则返回0if(s.len==0) return 1;else return 0;
}

6. 堆串比较函数

/*堆串比较函数*/
int StrCompare(HString s,HString t){//若串s和t相等,则返回0,若s>t返回1,若s<t返回-1int i;for(i=0;i<s.len && i<t.len;++i)if(s.ch[i]!=t.ch[i])return(s.ch[i]-t.ch[i]);return(s.len-t.len);
}

7. 求串长函数

/*求串长函数*/
int StrLength(HString s){//返回串s的长度return s.len;
}

8. 清空函数

/*清空函数*/
void StrClear(HString * s){//将串s置为空串if(s->ch!=NULL) free(s->ch);s->ch = NULL;s->len = 0;
}

9. 连接函数

/*连接函数*/
void StrCat(HString * s,HString t){//将串t联接在串s的后面int i;char * temp;temp = (char *)malloc(s->len+t.len);for(i=0;i<s->len;++i)temp[i] = s->ch[i];for(i=s->len;i<s->len+t.len;++i)temp[i] = t.ch[i-s->len];s->len += t.len;free(s->ch);s->ch = temp;
}

10. 求子串函数

/*求子串函数*/
void SubString(HString * sub,HString s,int pos,int len){//将串s中序号pos起len个字符复制到sub中int i;if(sub->ch!=NULL) free(sub->ch);if(pos<0 || pos>s.len || len<1 || len>s.len-pos){sub->ch = NULL;sub->len = 0;return;}else{sub->ch = (char *)malloc(len);for(i=0;i<len;++i)sub->ch[i] = s.ch[i+pos];sub->len = len;}
}

11. 定位函数

/*定位函数*/
int StrIndex(HString s,int pos,HString t){//求串t在串s中的位置int i,j;if(s.len==0 || t.len==0) return 0;i = pos;j = 0;while(i<s.len && j<t.len)if(s.ch[i]==t.ch[j]){i++;j++;}else{i = i-j+1;j = 0;}if(j>=t.len) return i-j;else return 0;
}

返回目录:

Chilan Yu:《数据结构》目录链接​zhuanlan.zhihu.com
e4dd86f54eef9aca57554d242ee40d4c.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/459223.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高光谱图像pca降维_高光谱图像的数据特性之探讨

图像是获取信息以及探知世界的重要媒介。近年来&#xff0c;传感科技与成像技术实现了跨越式发展&#xff0c;促使图像获取在质与量上均获得了显著提升。在多样化成像手段中&#xff0c;光谱成像技术是成像科技的重要组成部分&#xff0c;是人类借助光这一能量手段探测物质特性…

注册Tomcat服务为系统服务

2019独角兽企业重金招聘Python工程师标准>>> 将解压版的Tomcat服务注册为系统服务之后&#xff0c;就不用每次启动机器之后都要手动去启动"startup.bat"&#xff0c;就方便多了&#xff0c;下面就是具体步骤&#xff08;以我的机器为例&#xff0c;我的To…

【Spring学习笔记-MVC-17】Spring MVC之拦截器

作者&#xff1a;ssslinppp 1. 拦截器简介及应用场景2. 拦截器接口及拦截器适配器3. 运行流程图正常运行中断流程4. 程序实例控制层&#xff1a;ControllerRequestMapping(value "/test")public class TestController {RequestMapping(value "/intercept…

iOS之地理位置及定位系统 -- 入门笔记(用Swift)

前言&#xff1a;关于地理位置及定位系统&#xff0c;在iOS开发中也比较常见&#xff0c;比如美团外面的餐饮店铺的搜索&#xff0c;它首先需要用户当前手机的位置&#xff0c;然后在这个位置附近搜索相关的餐饮店铺的位置&#xff0c;并提供相关的餐饮信息&#xff0c;再比如最…

PHP监測memcache服务端的执行状况

. 代码例如以下&#xff0c;代码为memcache官方代码&#xff0c;引用在此。做一下简单的说明&#xff1a; 1、设置username和password define(ADMIN_USERNAME,admin); // Admin Username define(ADMIN_PASSWORD,123456); // Admin Password 2、配置server及其port&#xff0…

linux grep 匹配空格_17 个案例,5 分钟简单搞定 Linux 正则表达式!

正则表达式是一种字符模式&#xff0c;用于在查找过程中匹配制定的字符。元字符通常在Linux中分为两类&#xff1a;Shell元字符&#xff0c;由Linux Shell进行解析&#xff1b;正则表达式元字符&#xff0c;由vi/grep/sed/awk等文本处理工具进行解析&#xff1b;正则表达式一般…

micropython web ws2812_MicroPython实例之TPYBoard v102炫彩跑马灯WS2812B

一、实验目的了解ws2812b的工作原理学习ws2812b的驱动方法二、实验器材TPYBoard v102 1块ws2812b RGB-Ring-8 1个micro USB数据线 1条杜邦线 若干三、WS2812B的介绍WS2812B是一个集控制电路与发光电路于一体的智能外控LED光源。 其外型与一个5050LED灯珠相同&#xff0c; 每个元…

mysql数据库表复用_MySQL 数据库之表操作

一、创建表的完整语法create table 表(字段名1 类型 [(宽度) 约束条件]&#xff0c;字段名2 类型 [(宽度) 约束条件]&#xff0c;字段名3 类型 [(宽度) 约束条件])&#xff1b;1.类型&#xff1a;使用限制字段必须以什么样的数据类型传值约束条件&#xff1a;约束条件是在类型之…

Android有道词典查询功能

有道词典 任务要求&#xff1a;完成查词等功能 因为需要申请API key&#xff0c;这里直接给出地址供使用&#xff1a;http://fanyi.youdao.com/openapi?pathdata-mode 1、activity_main.xml基本格局&#xff08;不做任何说明&#xff09; 代码如下&#xff1a; 1 <Relative…

从零开始学Axure原型设计(高级篇)

如果你熟悉了Axure的部件库&#xff0c;那么你可以得心应手地画出心目中产品的线框图&#xff1b;如果你会用Axure的母版、动态面板功能&#xff0c;那么你应该能够画出一些简单网站的原型图&#xff1b;但只有你精通了Axure的条件逻辑、变量、函数等高级交互&#xff0c;才能将…

python vector 初始化_从零开始搭建机器学习算法框架(python)--计算框架

介绍今天开始一个新的系列&#xff0c;这个系列的目标是用python在不使用任何第三方库的情况下去实现各类机器学习或者深度学习的算法。之所以会有这种想法是因为每当我想提高编程技巧的时候&#xff0c;我总希望能够做一些简单又有趣的小项目练手。我一直对机器学习算法颇感兴…

windows phone 页面主题设计

达到如图这个效果&#xff1a; 1.保证状态栏背景色与主题栏颜色相同需设置状态栏的透明度&#xff0c;代码如下&#xff1a;shell:SystemTray.IsVisible"True" shell:SystemTray.Opacity"0.01" 2.顶部状态栏高度为25&#xff0c;字的上下要留部分空白3.内容…

JAVA如何才能导出这样的EXCEL?

2019独角兽企业重金招聘Python工程师标准>>> 最近的项目有个需求&#xff0c;需要做个报表&#xff0c;excel如上所示。没有很好的办法&#xff0c;求指教。 转载于:https://my.oschina.net/secret620/blog/611450

Xcode 修改工程名以及注意事项

1、先把整个工程文件夹名改为新的工程名。 2、打开工程&#xff0c;单击&#xff0c;输入新的工程名,会出现&#xff0c;点击确定。 3、回到工程界面&#xff0c;在中选择 Manage Schemes,然后再弹出的对话框&#xff0c;把工程名改为新的名字。 4、最好在工程中&#xff0c;把…

脚本命令配置mysql_MySQL 自动化部署脚本

一、环境说明操作系统&#xff1a;CentOS数据库版本&#xff1a;MySQL 5.7/8.0参数&#xff1a;buffer pool 会根据系统内存指定、默认双一、GTID、SlowLog脚本默认安装路径&#xff1a;/usr/local/mysql脚本默认数据路径&#xff1a;/data/mysql*(根据安装包版本适应 比如 5.7…

第2章 数字之魅——快速寻找满足条件的两个数

快速寻找满足条件的两个数 问题描述 能否快速找出一个数组中的两个数字&#xff0c;让这两个数字之和等于一个给定的数字&#xff0c;为了简化起见&#xff0c;我们假设这个数组中肯定存在这样一组或以上符合要求的解。 分析与解法 【解法一】 代码如下&#xff1a; 1 package …

eigen 列向量转矩阵_快速入门矩阵运算——开源库Eigen

矩阵是数学中一个重要的工具&#xff0c;广泛应用于各种场景下的数值分析&#xff0c;例如&#xff0c;数字信号处理&#xff0c;图像处理等。我们如何在程序中使用矩阵进行运算呢&#xff1f;本文将为大家介绍一个开源的矩阵运算工具——Eigen。Eigen is a C template library…

mysql raid_DBA们应该知道的RAID卡知识_MySQL

bitsCN.com对于数据库这种特殊应用IOphotoshop/ target_blank classinfotextkey>PS往往会成为瓶颈&#xff0c;突破的这个瓶颈的有效方法不多&#xff0c;软件方面主要是读写分离&#xff0c;垂直拆分&#xff0c;分区表技术&#xff0c;cluster。硬件方面主要是raid&#x…

基于Maven的SSH框架搭建

2019独角兽企业重金招聘Python工程师标准>>> 1.工程介绍 工程是结合了Springstruts2hibernate&#xff0c;实现了一个简单的form表单提交的功能&#xff0c;可能需要对spring&#xff0c;struts2&#xff0c;hibernate有一个基础的了解才好理解。 2.工程结构图 首先…

交通警察手势信号(动画演示)

*************************************************** 更多精彩&#xff0c;欢迎进入&#xff1a;http://shop115376623.taobao.com *************************************************** 一、交通警察手势信号&#xff0d;停止信号 二、交通警察手势信号&#xff0d;直行信…