C語言數(shù)據(jù)結(jié)構(gòu)之串插入操作
C語言數(shù)據(jù)結(jié)構(gòu)之串插入操作
實(shí)例代碼:
/* 串的堆分配存儲(chǔ)表示 */
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
#define OVERFLOW -2
typedef int Status;
typedef struct
{
char *ch; //如果是非空串,則按串長分配存儲(chǔ)區(qū),否則ch為NULL
int length; //串長度
}HString;
/*******************************聲明部分****************************************/
Status StrAssign(HString *T,char *chars);
//生成一個(gè)其值等于串常量chars的串T
Status StrInsert (HString *S,int pos,HString T);
//1<=pos<=StrLength(S)+1.在串S的第pos個(gè)字符之前插入串T
int StrLength(HString S);
//返回S的元素個(gè)數(shù),成為串的長度
int StrCompare(HString S,HString T);
//若S>T,則返回值>0,若S=T,則返回值 = 0,若S<T,則返回值<0
Status ClearString(HString *S);
//將S清空
Status Concat(HString *T,HString S1,HString S2);
//用T返回由S1和S2連接而成的新串
Status SubString(HString *Sub,HString S,int pos,int len);
//用Sub返回串S的第pos個(gè)字符起長度為len的子串
//其中,1<= pos<= StrLength(S) 且 0<= len <= StrLength(S)-pos+1
Status StrCopy(HString *T, HString S);
/*******************************函數(shù)部分****************************************/
Status StrAssign(HString *T,char *chars)
{
if((*T).ch){ //釋放舊空間
free((*T).ch);
}
int i = strlen(chars);
if(!i){ //若chars為空
(*T).ch = NULL;
(*T).length = 0;
}
else{ //chars不空
if(!((*T).ch = (char *)malloc(i * sizeof(char)))) //為T分配chars所需的存儲(chǔ)空間
exit(OVERFLOW);
int count;
for(count = 0;count <= i-1;count++){ //把chars存入T中
(*T).ch[count] = chars[count];
(*T).length = i;
} //for
} //else
return OK;
}
int StrLength(HString S)
{
return S.length;
}
int StrCompare(HString S,HString T)
{
int count;
for(count = 0;count < S.length && count < T.length;count++){
if(S.ch[count] != T.ch[count])
return S.ch[count] - T.ch[count];
}
return S.length - T.length;
}
Status ClearString(HString *S)
{
if((*S).ch){
free((*S).ch);
(*S).ch = NULL;
}
(*S).length = 0;
return OK;
}
Status Concat(HString *T,HString S1,HString S2)
{
if((*T).ch){ //釋放舊空間
free((*T).ch);
}
if(!((*T).ch = (char *)malloc((S1.length+S2.length)* sizeof(char))))
exit(OVERFLOW);
int count,cnt;
for(count = 0;count <= S1.length;count++){ //把S1存入T中
(*T).ch[count] = S1.ch[count];
}
(*T).length = S1.length + S2.length; //更改T的長度為兩串之和
for(count = S1.length,cnt = 0;count <= (*T).length;count++,cnt++){
(*T).ch[count] = S2.ch[cnt]; //把S2存入T中
}
return OK;
}
Status SubString(HString *Sub,HString S,int pos,int len)
{
if(pos<1 || pos>S.length || len<0 || len >S.length-pos+1)
return ERROR;
if((*Sub).ch){ //釋放舊空間
free((*Sub).ch);
}
if(!len){
(*Sub).ch = NULL;
(*Sub).length = 0; //空子串
}
else{ //完整子串
(*Sub).ch = (char *)malloc(len*sizeof(char));
int count,cnt;
for(count = 0,cnt = pos-1;count <= len-1;count++,cnt++){
(*Sub).ch[count] = S.ch[cnt];
}
(*Sub).length = len;
}//else
return OK;
}
Status StrInsert (HString *S,int pos,HString T)
{
if(pos<1 || pos >(*S).length+1)
return ERROR; //pos不合法
if(T.length){
if(!((*S).ch = (char*)realloc((*S).ch,((*S).length + T.length)*sizeof(char))))
exit(OVERFLOW);
int count,cnt;
for(count = (*S).length-1;count>= pos-1;count--){
(*S).ch[count+T.length-1] = (*S).ch[count]; //為插入T騰出位置
}
for(count = pos-1,cnt = 0;cnt<= T.length-1;count++,cnt++)
(*S).ch[count] = T.ch[cnt]; //插入T
(*S).length += T.length;
}//if
return OK;
}
Status StrCopy(HString *T, HString S){
int j;
if((*T).ch)
free((*T).ch);
(*T).ch = (char*)malloc(S.length * sizeof(char));
if(!(*T).ch)
exit(OVERFLOW);
for(j = 0; j < S.length; j++)
(*T).ch[j] = S.ch[j];
(*T).length = S.length;
return OK;
}
/*******************************主函數(shù)部分**************************************/
int main()
{
HString T,S,S1,S2,Sub;
char *charsT = "abcd";
char *chars1 = "abc";
char *chars2 = "AAAA";
StrAssign(&T,charsT);
StrAssign(&S,chars1);
StrAssign(&S1,chars1);
StrAssign(&S2,chars2);
int count;
printf("T的長度為:%d\n",T.length);
printf("T的內(nèi)容為:");
for(count = 0;count <T.length;count++){
printf("%c",T.ch[count]);
}
printf("\n");
printf("\nStrCompare(S,T) = %d\n",StrCompare(S,T));
Concat(&T,S1,S2);
printf("\n鏈接S1,S2為T之后\n");
printf("T的長度為:%d\n",T.length);
printf("T的內(nèi)容為:");
for(count = 0;count <T.length;count++){
printf("%c",T.ch[count]);
}
printf("\n");
printf("\nS的長度為:%d\n",S.length);
printf("S的內(nèi)容為:");
for(count = 0;count <S.length;count++){
printf("%c",S.ch[count]);
}
printf("用Sub返回S的第1個(gè)字符起長度為2的子串\n");
SubString(&Sub,S,1,2);
printf("Sub的長度為:%d\n",Sub.length);
printf("Sub的內(nèi)容為:");
for(count = 0;count <Sub.length;count++){
printf("%c",Sub.ch[count]);
}
printf("\n");
printf("\n在串S的第1個(gè)字符之前插入串T\n");
StrInsert(&S,1,T);
printf("S的長度為:%d\n",S.length);
printf("S的內(nèi)容為:");
for(count = 0;count <S.length;count++){
printf("%c",S.ch[count]);
}
return 0;
}
實(shí)現(xiàn)效果:
如有疑問請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
欄 目:C語言
下一篇:C++中回調(diào)函數(shù)及函數(shù)指針的實(shí)例詳解
本文標(biāo)題:C語言數(shù)據(jù)結(jié)構(gòu)之串插入操作
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1063.html
您可能感興趣的文章
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用函數(shù)刪除字符
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)式函數(shù)庫
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)數(shù)怎么表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段函數(shù)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排序法函數(shù)
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02C語言中怎么打出三角函數(shù) c語言中怎么打出三角函數(shù)的值
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求階乘


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 01-10C#中split用法實(shí)例總結(jié)
- 04-02jquery與jsp,用jquery
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05織夢dedecms什么時(shí)候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢data目錄下的sessions文件夾有什


