返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言的堆串实例操作分析
  • 912
分享到

C语言的堆串实例操作分析

2023-06-29 03:06:44 912人浏览 泡泡鱼
摘要

今天小编给大家分享一下C语言的堆串实例操作分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、堆串概念与定长顺序穿的存储结

今天小编给大家分享一下C语言的堆串实例操作分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

一、堆串概念

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

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

二、基本操作

#include<stdio.h>#include<stdlib.h>#include<string.h>#define false 0#define true 1typedef 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语言的堆串实例操作分析”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网其他教程频道。

--结束END--

本文标题: C语言的堆串实例操作分析

本文链接: https://lsjlt.com/news/322464.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言的堆串实例操作分析
    今天小编给大家分享一下C语言的堆串实例操作分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、堆串概念与定长顺序穿的存储结...
    99+
    2023-06-29
  • C语言的堆串操作详解
    目录一、堆串概念。二、基本操作。三、运行:总结一、堆串概念。 与定长顺序穿的存储结构类似,都是用一组地址连续的存储单元存储串的字符序列,不同的是堆串的存储空间是动态分配的,只要存储空...
    99+
    2024-04-02
  • C语言文件的操作实例分析
    这篇文章主要介绍了C语言文件的操作实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言文件的操作实例分析文章都会有所收获,下面我们一起来看看吧。一、为什么使用文件当我们写一些项目的时候,我们应该要把写的...
    99+
    2023-06-30
  • C语言文件操作实例分析
    这篇文章主要介绍了C语言文件操作实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言文件操作实例分析文章都会有所收获,下面我们一起来看看吧。一、为什么使用文件?当我们在编写一个项目的时候,自然而然想到要...
    99+
    2023-07-02
  • C语言中的文件操作实例分析
    这篇文章主要介绍了C语言中的文件操作实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言中的文件操作实例分析文章都会有所收获,下面我们一起来看看吧。1.为什么使用文件在学习结构体时,写了一个简易的通讯录...
    99+
    2023-07-02
  • C语言操作符使用实例分析
    本篇内容介绍了“C语言操作符使用实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!算术操作符主要是 (+ - * / %) 五种算数操作...
    99+
    2023-07-02
  • C语言操作符的示例分析
    这篇文章给大家分享的是有关C语言操作符的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言C语言中操作符不多,但是有些相同的操作符都是在不同的表达式中,有不同的解释意思,比如 * 号,在表达式中5*5表示...
    99+
    2023-06-20
  • C语言字符串实例分析
    本篇内容主要讲解“C语言字符串实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言字符串实例分析”吧!看下面这个我们熟知的也是最先学习的代码"Hello world!"...
    99+
    2023-06-29
  • C语言中单目操作符++、–的实例分析
    C语言中单目操作符++、–的实例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。前言大家先判断下下面代码的运行结果答案:如果你全对了,那么恭喜大佬,这篇博客可能对你收益不大,...
    99+
    2023-06-22
  • C语言实现堆的简单操作的示例代码
    目录一、堆的概念二、堆的实现三、堆的代码实现一、堆的概念 (1)定义 如果有一个关键码的集合K = {k0,k1, k2,…,kn-1},把它的所有元素按完全二叉树的顺...
    99+
    2022-11-13
    C语言实现堆 C语言 堆操作 C语言
  • C语言文件操作分析
    本篇内容介绍了“C语言文件操作分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!文件的随机读写之前的函数只能实现顺序读写,而实现随机读写需用...
    99+
    2023-06-25
  • R语言操作XML文件实例分析
    XML是一种文件格式,它使用标准ASCII文本共享万维网,内部网和其他地方的文件格式和数据。 它代表可扩展标记语言(XML)。 类似于HTML它包含标记标签。 但是与HTML中的标记...
    99+
    2024-04-02
  • C语言数据结构堆排序示例分析
    今天小编给大家分享一下C语言数据结构堆排序示例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。TOP.堆排序前言什么是堆排...
    99+
    2023-06-30
  • C语言数据结构堆的基本操作实现
    目录1.基本函数实现a.代码1(向下调整)b.代码2(向上调整)c.代码3(交换)2.建堆 3.插入数据4. 删除数据5.获取堆顶的数据6.堆的数据个数7.判空8.打印9.销毁10....
    99+
    2024-04-02
  • C语言数据结构之堆、堆排序的分析及实现
    目录 1.堆的概念结构及分类1.2堆的分类1.2.1 大堆1.2.2 小堆2. 堆的主要接口3.堆的实现3.1 堆的初始化 HeapInit3.2 堆的销毁 HeapDes...
    99+
    2024-04-02
  • C语言字符串基础使用实例分析
    本篇内容介绍了“C语言字符串基础使用实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、字符串的概念字符串是有序字符的集合字符串是程序...
    99+
    2023-06-30
  • C语言分支语句实例分析
    这篇文章主要介绍了C语言分支语句实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言分支语句实例分析文章都会有所收获,下面我们一起来看看吧。C语言的语句C语句可分为以下五类: 表达式语句 函数调用语句 ...
    99+
    2023-06-30
  • C语言入门基础之操作符的示例分析
    这篇文章给大家分享的是有关C语言入门基础之操作符的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。操作符首先第一部分操作符分类如上,具体不再用文字阐述。算术操作符首先算术操作符,有除号值得一讲,若想得浮点数...
    99+
    2023-06-20
  • C#操作Excel实现的实例分析
    C#操作Excel实现的实例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。C#操作Excel是怎么样执行的呢?我们在实际的C#操作Excel开发程序过程中主要会使用到那些方...
    99+
    2023-06-17
  • MySQL中DML语言操作的示例分析
    这篇文章主要介绍MySQL中DML语言操作的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!补充说明,外键:不要使用外键,一切外键概念都在应用层解决。补充说明,数据库的列,也就...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作