C 언어 데이터 구조의 직렬 삽입 작업
인 스 턴 스 코드:
/* */
#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 NULL
int length; //
}HString;
/******************************* ****************************************/
Status StrAssign(HString *T,char *chars);
// chars T
Status StrInsert (HString *S,int pos,HString T);
//1<=pos<=StrLength(S)+1. S pos T
int StrLength(HString S);
// S ,
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 len
// ,1<= pos<= StrLength(S) 0<= len <= StrLength(S)-pos+1
Status StrCopy(HString *T, HString S);
/******************************* ****************************************/
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
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;
}
/******************************* **************************************/
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
",T.length);
printf("T :");
for(count = 0;count <T.length;count++){
printf("%c",T.ch[count]);
}
printf("
");
printf("
StrCompare(S,T) = %d
",StrCompare(S,T));
Concat(&T,S1,S2);
printf("
S1,S2 T
");
printf("T :%d
",T.length);
printf("T :");
for(count = 0;count <T.length;count++){
printf("%c",T.ch[count]);
}
printf("
");
printf("
S :%d
",S.length);
printf("S :");
for(count = 0;count <S.length;count++){
printf("%c",S.ch[count]);
}
printf(" Sub S 1 2
");
SubString(&Sub,S,1,2);
printf("Sub :%d
",Sub.length);
printf("Sub :");
for(count = 0;count <Sub.length;count++){
printf("%c",Sub.ch[count]);
}
printf("
");
printf("
S 1 T
");
StrInsert(&S,1,T);
printf("S :%d
",S.length);
printf("S :");
for(count = 0;count <S.length;count++){
printf("%c",S.ch[count]);
}
return 0;
}
구현 효과:궁금 한 점 이 있 으 시 면 메 시 지 를 남기 거나 본 사이트 의 커 뮤 니 티 에 가서 토론 을 교류 하 세 요.읽 어 주 셔 서 감사합니다. 도움 이 되 셨 으 면 좋 겠 습 니 다.본 사이트 에 대한 지지 에 감 사 드 립 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
정수 반전Udemy 에서 공부 한 것을 중얼거린다 Chapter3【Integer Reversal】 (예) 문자열로 숫자를 반전 (toString, split, reverse, join) 인수의 수치 (n)가 0보다 위 또는 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.