string.h

来自「《数据结构-使用C语言》第三版」· C头文件 代码 · 共 76 行

H
76
字号
//串处理 静态数组 
typedef struct
{
	char str[MaxSize];
	int length;
}String;

void Initiate(String *S)
{
	S->length=0;
}

int Insert(String *S, int pos, String T)
{
	int i;
	if(pos<0 || pos > S->length)
	{
		printf("参数pos出错!\n");
		return 0;
	}
	else if(S->length + T.length>MaxSize)
	{
		printf("数组空间不足!\n");
		return 0;
	}
	else
	{
		for(i=S->length-1; i>=pos; i--)
		S->str[i+T.length]=S->str[i];
		
		for(i=0; i<T.length; i++)
		S->str[pos+T.length]=T.str[i];
		S->length=S->length+T.length;
		return 1;
	}
}

int Delete(String *S, int pos, int len)
{
	int i;
	if(S->length<=0)
	{
		printf("数组为空无法删除!\n");
		return 0;
	}
	else if(pos<0 || len<0 ||pos+len>S->length)
	{
		printf("参数不合法!\n");
		return 0;
	}
	else 
	{
		for(i=pos+len;i<=S->length-1;i++)
		S->str[i-len]=S->str[i];
		S->length=S->length-len;
		return 1;
	}
}

int SubString(String S, int pos, int len, String *T)
{
	int i;
	if(pos<0 || len<0 || pos+len>S.length)
	{
		printf("参数出错!\n");
		return 0;
	}
	else 
	{
		for(i=0;i<len;i++)
		T->str[i]=S.str[pos+i];
		T->length=len;
		return 1;
	}
} 

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?