91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言的堆串實例操作分析

發布時間:2022-02-14 09:21:08 來源:億速云 閱讀:122 作者:iii 欄目:開發技術

今天小編給大家分享一下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語言的堆串實例操作分析”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

将乐县| 澄迈县| 义马市| 新平| 清新县| 舟山市| 汾阳市| 绥德县| 焦作市| 曲周县| 茂名市| 东乌珠穆沁旗| 霍城县| 永福县| 弥勒县| 苍南县| 临夏县| 尤溪县| 兴宁市| 息烽县| 台江县| 丹棱县| 宁陕县| 定结县| 班戈县| 筠连县| 四川省| 灌阳县| 普宁市| 荆门市| 福建省| 隆安县| 新宁县| 杭锦旗| 伊春市| 赞皇县| 万盛区| 钦州市| 禹州市| 江城| 军事|