存储过程 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,一经查实,立即删除!

相关文章

iOS UIWebView URL拦截

http://www.cocoachina.com/ios/20150626/12161.html 本文译者&#xff1a;candeladiao&#xff0c;原文&#xff1a;URL filtering for UIWebView on the iPhone说明&#xff1a;译者在做app开发时&#xff0c;因为页面的javascript文件比较大导致加载速度很慢&#xff0c;所以…

nginx的upstream目前支持5种方式的分配

nginx的upstream目前支持5种方式的分配1、轮询&#xff08;默认&#xff09;每个请求按时间顺序逐一分配到不同的后端服务器&#xff0c;如果后端服务器down掉&#xff0c;能自动剔除。2、weight指定轮询几率&#xff0c;weight和访问比率成正比&#xff0c;用于后端服务器性能…

1216: 斐波那契数列

From: 合工宣OJ http://xcacm.hfut.edu.cn/problem.php?id1216 时间限制: 1 Sec 内存限制: 128 MB 题目描述 Fibonacci数列&#xff0c;定义如下&#xff1a; f(1)f(2)1 f(n)f(n-1)f(n-2) n>3 计算第n项Fibonacci数值。 输入 输入第一行为一个整数n&#xff08;1<…

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

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

RequestMapping

转自&#xff1a;http://blog.csdn.net/kobejayandy/article/details/12690041 简介&#xff1a;RequestMappingRequestMapping是一个用来处理请求地址映射的注解&#xff0c;可用于类或方法上。用于类上&#xff0c;表示类中的所有响应请求的方法都是以该地址作为父路径。Requ…

mysql 8.0 yum_CentOS8 安装 MySQL8.0(yum)

1、Mysql 官网下载 RPM 包wget https://dev.mysql.com/get/mysql80-community-release-el8-1.noarch.rpm2、检查是否已安装(强力卸载)for i in $(rpm -qa|grep mysql);do rpm -e $i --nodeps;donerm -rf /var/lib/mysql && rm -rf /etc/my.cnf && rm -rf /usr/…

CASIO 5800P计算器游戏--猜数字游戏

CASIO 5800P 计算器游戏--猜数字游戏原代码我编的计算器小游戏--猜数字游戏 LbI I↙ "xxGUESS NUMBERxx xPROGRAMMER:JCHx ---------------- START>>>>>>>[EXE]"◢ LbI Q↙ "xxxDIFFICULTYxxx[1EASY][2MIDDLE][3HARD]"?→N: N1>G…

注册Tomcat服务为系统服务

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

mysql mtop_mysqlmtop2.2运行出错

ADatabaseErrorOccurredUnabletoconnecttoyourdatabaseserverusingtheprovidedsettings.Filename:core/Loader.phpLineNumber:346mysqlmtop/etc/config.ini配置&#xff1a;###监控机MySQL数据库...A Database Error OccurredUnable to connect to your database server using …

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

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

Angular浅入深出系列 - 写在前面

本系列目录&#xff1a;写在前面基础知识控制器&#xff08;Controller&#xff09;作用域&#xff08;Scope&#xff09;集合&#xff08;Collection&#xff09;模块&#xff08;Module&#xff09;依赖注入&#xff08;Dependency Injection&#xff09;服务&#xff08;Ser…

PHP 错误与异常 笔记与总结(12 )异常

① 异常的概念&#xff1b;异常和错误的区别 PHP 部分借鉴了 C 和 JAVA 中的异常处理机制。PHP 中的异常是指 程序运行和预期不太一致&#xff0c;与错误是两个不同的概念。 ② 异常的语法结构 【例1】 1 <?php2 header(content-type:text/html; charsetutf-8);3 /*4 t…

python中交换a和b的值_交换A和B之间的元素以获得和相等

如果有这样的互换&#xff0c;那么两个值之间的差值必须是总和差的一半。交换两个值意味着两个列表的总和将改变&#xff0c;一个上升&#xff0c;另一个下降&#xff0c;以相同的数量。这两个变化必须加上掉期前的和之间的差值&#xff0c;且两个总和都会以相同的值(^{cd1>…

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

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

python的三大错误类型_学习Python时要避免的三个错误

当你做错事时&#xff0c;承认错误并不是一件容易的事&#xff0c;但是犯错是任何学习过程中的一部分&#xff0c;无论是学习走路&#xff0c;还是学习一种新的编程语言都是这样&#xff0c;比如学习 Python。为了让初学 Python 的程序员避免犯同样的错误&#xff0c;以下列出了…

Extjs中给同一个GridPanel中的事件添加参数的方法

Extjs中给同一个GridPanel中的事件添加参数的方法&#xff1a; this.isUse new Ext.Action({ text:启用, scope:this, handler:this.isUseWin.createDelegate (this,[1]) }); this.isNotUse new Ext.Action({ tex…

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;正则表达式一般…

C# 泛型使用笔记

泛型的基本概念我就不在这重复了&#xff0c;不了解的同学请自行百度。 我主要写下我在项目中要到的泛型实例。献丑了.....有什么不好或不对的地方大家尽可评论留言。 为什么要用泛型&#xff1f; 通过使用泛型&#xff0c;我们可以极大地提高代码的重用度&#xff0c;同时还可…

汇编题目:编写包含多个功能子程序的中断例程

安装一个新的int 7ch中断例程&#xff0c;为显示输出提供如下的功能子程序。 &#xff08;1&#xff09;清屏。&#xff08;2&#xff09;设置前景色。&#xff08;3&#xff09;设置背景色。&#xff08;4&#xff09;向上滚动一行 &#xff08;一&#xff09;用ah寄…