C语言的堆串操作详解

 更新时间:2022年02月13日 14:52:42   作者:犀牛超人  
大家好,本篇文章主要讲的是C语言的堆串操作详解,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下

一、堆串概念。

与定长顺序穿的存储结构类似,都是用一组地址连续的存储单元存储串的字符序列,不同的是堆串的存储空间是动态分配的,只要存储空间分配成功,就不会担心串在插入或者连接时候出现截断的情况。

 malloc(),free(),realloc()  这三个函数用来对动态存储进行操作。

二、基本操作。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define false 0
#define true 1
typedef struct {
	char *ch;    //字符数组,若是非空则指向起始地址,若为空则NULL 
	int len;   //长度 
}HString;
//初始化
int HInit(HString *s){
	s->ch=NULL;
	s->len=0;
} 
//串赋值
int HStrAssign(HString *s,const char *chars){
	int i=0;
	while(chars[i]!='\0'){    //确定串长 
		i++;
	}
	s->len=i;
	if(s->ch!=NULL){
		free(s);
	}else{
		s->ch=(char *)malloc((s->len+1)*sizeof(char));//0号单元不用
		if(s==NULL){
			printf("空间申请失败!");
			return false;
		} 
	for( i=1;i<=s->len;i++){   //依次赋值 
		s->ch[i]=chars[i-1];
	}
	}
}
//串遍历
int HSbianli(HString *s){
	if(s->len==0){
		printf("串空!");
		return false; 
	}else{
		int i;
		for(i=1;i<=s->len;i++){
			printf("%c",s->ch[i]);
		}
		return true;
	}
} 
//串插入
int HStrInsert(HString *s,int pos,const HString t){
	if(pos<1||pos>s->len){
		printf("位置不合法!");
		return false;
	}
	char *temp;
	temp=(char *)malloc((s->len+t.len+1) *sizeof(char));
	int i;
	for(i=1;i<pos;i++){    //将s串pos之前(不含pos)的字符赋给temp 
		temp[i]=s->ch[i];
	}
	for(i=pos;i<pos+t.len;i++){   //将t串的元素赋给s 
		temp[i]=t.ch[i-pos+1];
	}
	for(i=0;i<=s->len-pos;i++){
		temp[pos+t.len+i]=s->ch[i+pos];
	}
	free(s->ch);
	s->ch=temp;
	s->len=s->len+t.len;
	return true; 
} 
//串删除
int HStrDelete(HString *s,int pos,int len){
	if(s->len==0){
		printf("串空!");
		return false;
	}else if(len>=s->len){
		printf("非法位置!");
		return false;
	}else{
		for(int i=pos;i<s->len-pos;i++){   //跨度为len的依次赋值 
			s->ch[i]=s->ch[i+len];
		}
		s->len=s->len-len;
		return true;
	}
} 
//串连接
 int HStrCon(HString *s,const HString t){
 	s->ch=(char *)realloc(s->ch,(s->len+t.len+1) *sizeof(char));
 	if(s==NULL){
 		printf("空间申请失败!");
 		return false;
	 }
	if(s->len==0){
		printf("串空!");
		return false;
	}else{
		for(int i=1;i<=t.len;i++){
			s->ch[i+s->len]=t.ch[i];
		}
		s->len=s->len+t.len;
		return true;
	}
 }
 //求字串
 int HStrchild(HString *s,int pos,int len){
 	if(s->len==0){
 		printf("串空!");
 		return false;
	 }else{
	 	for(int i=0;i<len;i++){
	 		printf("%c",s->ch[i+pos]);
		 }
		 return true;
	 }
 }
 
int main(){
	HString s;
	HString s1;
	HInit(&s);
	HInit(&s1);
	char a[]={"aaaaa"};
	char b[]={"bbb"};
	HStrAssign(&s,a);
	HStrAssign(&s1,b);
	printf("-----将aaaaa赋值给s,bbb赋值给s1-----\n");
	printf("此时串s为:"); 
	HSbianli(&s);
	printf("\n此时串s1为:"); 
	HSbianli(&s1);
	printf("\n将s1连接到s为:"); 
	HStrCon(&s,s1);
    HSbianli(&s); 
	printf("\n将串s1插入到s串的第二个位置:");
	HStrInsert(&s,2,s1);
	HSbianli(&s);
	printf("\n再将插入的s1串删除:");
	HStrDelete(&s,2,3);
	HSbianli(&s);
	printf("\ns1在第二个元素长度为2的子串为:");
	HStrchild(&s,2,2);
}

三、运行:

 代码可运行。

总结

到此这篇关于C语言的堆串操作详解的文章就介绍到这了,更多相关C语言堆串内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • c++语言中虚函数实现多态的原理详解

    c++语言中虚函数实现多态的原理详解

    这篇文章主要给大家介绍了关于c++语言中虚函数实现多态的原理的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用c++语言具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • C语言实现扫雷附完整代码

    C语言实现扫雷附完整代码

    本文详细讲解了C语言实现扫雷并附完整代码,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-11-11
  • 详解C++编译器优化技术

    详解C++编译器优化技术

    现代编译器缺省会使用RVO(return value optimization,返回值优化)、NRVO(named return value optimization、命名返回值优化)和复制省略(Copy elision)技术,来减少拷贝次数来提升代码的运行效率。
    2021-06-06
  • 深入理解C++内链接与外链接的意义

    深入理解C++内链接与外链接的意义

    链接描述了名称在整个程序或一个翻译单元中如何引用或不引用同一实体,下面这篇文章主要给大家介绍了关于C++内链接与外链接意义的理解,需要的朋友可以参考下
    2021-11-11
  • Win11+ VS2022编译 FFmpeg6.0 静态库的详细过程

    Win11+ VS2022编译 FFmpeg6.0 静态库的详细过程

    这篇文章主要介绍了Win11+VS2022编译FFmpeg6.0静态库的方法,本文通过图文实例代码相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • C++字符数组、字符数组指针和string类

    C++字符数组、字符数组指针和string类

    这篇文章主要介绍了C++字符数组、字符数组指针和string类,string是一个类而不是基本数据类型,数组不含有处理函数,下面更多详细内容,需要的小伙伴可以参考下面文章
    2022-03-03
  • 有关C++中随机函数rand() 和srand() 的用法详解

    有关C++中随机函数rand() 和srand() 的用法详解

    下面小编就为大家带来一篇有关C++中随机函数rand() 和srand() 的用法详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • OpenCV实现绘制轮廓外接矩形

    OpenCV实现绘制轮廓外接矩形

    这篇文章主要为大家详细介绍了OpenCV实现绘制轮廓外接矩形的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-12-12
  • C语言线索二叉树基础解读

    C语言线索二叉树基础解读

    线索二叉树还是按照链二叉树的方法创建,只不过在结点原本为空的左指针改为指向该结点在中序遍历中的前驱,结点原本为空的右指针改为指向该结点在中序遍历中的后继,也就是说把空的指针给利用了起来
    2022-04-04
  • Cocos2d-x触摸事件实例

    Cocos2d-x触摸事件实例

    这篇文章主要介绍了Cocos2d-x触摸事件实例,本文代码中包含大量注释来说明Cocos2d-x中的触摸事件使用示例,需要的朋友可以参考下
    2014-09-09

最新评论