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语言堆串内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C语言复数的加减及输出结构体

    一. #include<stdio.h> typedef struct complex { int real; //实部 int imag; //虚部 }complex; /* 功能:复数加法 参数:两个复数 返回值:两个复数的和 */ complex complexadd(complex x,complex y) { complex sum; sum.real = x.real + y.real; sum.imag = x.imag + y.imag; return sum; } /* 功能

  • C语言数组全面总结梳理

    目录 一,一维数组 1.创建和初始化 2.使用下标访问 3.在内存中的存储 二,二维数组 1.创建和初始化 2.使用下标访问 3.在内存中的存储 三,越界问题 数组(array)是由一系列类型相同的元素构成. 一般形式: 类型     数组名  [常量表达式] 一,一维数组 1.创建和初始化 创建一堆相同元素的集合,以整型为例: //创建大小为8的整型数组 int arr1[8]; // []里面应放常量,因此若: int num=8; //则有: arr2[num]; num为变量,创建失败

  • C语言的堆串操作详解

    目录 一.堆串概念. 二.基本操作. 三.运行: 总结 一.堆串概念. 与定长顺序穿的存储结构类似,都是用一组地址连续的存储单元存储串的字符序列,不同的是堆串的存储空间是动态分配的,只要存储空间分配成功,就不会担心串在插入或者连接时候出现截断的情况. malloc(),free(),realloc()  这三个函数用来对动态存储进行操作. 二.基本操作. #include<stdio.h> #include<stdlib.h> #include<string.h> #d

  • C语言中的文件操作详解

    目录 1.为什么使用文件 2.什么是文件 2.1程序文件 2.2数据文件 2.3文件名 3.文件的打开和关闭 3.1文件指针 3.2文件的打开和关闭 4.文件的顺序读写 5.文件的随机读写 5.1fseek 5.2ftell 5.3rewind 6.文本文件和二进制文件 7.文件读取结束的判定 7.1被错误使用的feof 8.文件缓冲区 结论 1.为什么使用文件 在学习结构体时,写了一个简易的通讯录的程序,当程序运行起来的时候,可以在通讯录中增加和删除数据,此时数据是存放在内存当中的,当程序退出

  • C语言进阶之文件操作详解

    目录 0.Intro 1.文件名 2.文件的打开和关闭 2.1文件指针 2.2打开和关闭文件 3.文件顺序读写 3.1利用以上函数实现拷贝文件操作 3.2二进制的读写 3.3格式化输入输出函数 4.文件的随机读写操作 4.1fseek 4.2ftell 4.3rewind 5.文本文件和二进制文件 5.1一个数据在内存中的存储方式 6.文件读取错误的判定 6.1被错误使用的feof 7.文件缓冲区 7.1行缓冲 总结 0. Intro 在使用操作数据库之前,记录信息,录入数据需要文件操作,这样就

  • C语言编程C++旋转字符操作串示例详解

    目录 旋转字符串 字符串左旋 题前认知: 暴力移位: 三步翻转: 判断字符串旋转 题前认知 字符串追加判断 旋转字符串 字符串左旋 实现一个函数,可以左旋字符串中的k个字符. 例如: ABCD左旋一个字符得到BCDA ABCD左旋两个字符得到CDAB 题前认知: 一个字符串如果就定死了.eg:char arr[]="dfdf"什么的那多没意思,一点都没有人机交互的感觉,(虽然现在人机交互适合个体,不适合集群,但也是比死板的定死字符串舒服) 所以字符串得是我们可输入的,才有可玩性,玩的不

  • GO语言基本类型String和Slice,Map操作详解

    目录 本文大纲 1.字符串String String常用操作:获取长度和遍历 字符串的strings包 字符串的strconv包: 2.切片Slice 3.集合Map 本文大纲 本文继续学习GO语言基础知识点. 1.字符串String String是Go语言的基本类型,在初始化后不能修改,Go字符串是一串固定长度的字符连接起来的字符序列,当然它也是一个字节的切片(Slice). import ("fmt") func main() { name := "Hello World

  • R语言对二进制文件操作详解

    二进制文件是包含仅以位和字节(0和1)的形式存储的信息的文件.它们不是人类可读的,因为它中的字节转换为包含许多其他不可打印字符的字符和符号.尝试使用任何文本编辑器读取二进制文件将显示如Ø和ð的字符. 二进制文件必须由特定程序读取才能使用.例如,Microsoft Word程序的二进制文件只能通过Word程序读取到人类可读的形式.这表示,除了人类可读的文本之外,还有更多的信息,例如字符和页码等的格式化,它们也与字母数字字符一起存储.最后一个二进制文件是一个连续的字节序列.我们在文本文件中看到的换行

  • C语言实现顺序表的全操作详解

    目录 线性表 顺序表 顺序表接口实现 1.顺序表初始化 2.顺序表空间增容 3.顺序表打印 4.尾插数据 5.尾删数据 6.头插数据 7.头删数据 8.在pos下标处插入数据 9.删除pos下标处数据 10.数据查找 11.顺序表摧毁 线性表 线性表(linear list)是n个具有相同特性的数据元素的有限序列.线性表是一种在实际中广泛使用的数据结构,常见的线性表有:顺序表.链表.栈.队列.字符串等. 线性表在逻辑上是线性结构,也就是连续的一条直线.但在物理结构上并不一定是连续的,线性表在物理

  • Go语言学习笔记之文件读写操作详解

    目录 文件写 文件读 小结 文件操作比较多,分为几篇来写吧.首先是文件的读写,在平时的工程化操作中使用最多. 文件写 样例代码如下 package main import ( "bufio" "fmt" "io" "os" ) //写文件 func DoWriteFile() error { _filePath := "./test.txt" _file, _err := os.OpenFile(_file

  • C语言数据结构之单链表操作详解

    目录 1.插入操作 2.删除操作 3.查找操作 4.修改操作 5.完整代码 1.插入操作 (1)创建一个新的要插入的结点 (2)将新结点的 next 指针指向插入位置后的结点 (3)将插入位置前的节点指针 next 指向新的结点 注意:步骤(2)(3)的顺序不能颠倒,否则会导致插入位置后的部分链表丢失. 插入位置一共分三种,分别是头部插入.中间插入和尾部插入. 如图: 代码: link* insertElem(link* p,int elem,int pos){ link* temp = p;/

  • Go语言Goroutinue和管道效率详解

    目录 goroutinue基本介绍 进程和线程说明 并发和并行 同步和异步 Go协程和Go主线程 go协程特点 goroutinue基本使用 实验代码 效果图 执行流程图 goroutinue的调度模型 MPG MPG运行状态1 MPG运行状态2 管道(channel) 不同协程之间如何通讯 全局变量加锁同步缺陷 管道基本介绍 管道基本使用 声明和定义 管道关闭和遍历 关闭 遍历 管道注意事项 综合案例 goroutinue基本介绍 进程和线程说明 进程介绍程序在操作系统中的一次执行过程,是系统

随机推荐