String_Sequence(字符串的顺序存储)

本文介绍了一种使用C语言实现的字符串操作方法,包括插入、删除、连接及子串获取等功能,并通过具体实例展示了这些操作的使用过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<stdio.h>
#define MAXSIZE 100
typedef struct {
char str[MAXSIZE];
int length;
}seq;


void strinsert(seq *s, int i, seq t)
{
if (i<1 || i>MAXSIZE + 1 || s->length + t.length > MAXSIZE)
printf("不能进行插入!\n");
else
{
int k;
for (k = s->length - 1; k >= i - 1; k--)
s->str[k + t.length] = s->str[k];
for (k = 0; k < t.length; k++)
s->str[i - 1 + k] = t.str[k];
s->length = s->length + t.length;
s->str[s->length] = '\0';
}
}


void strdele(seq *s, int i, int len)
{
if (i<1 || i>MAXSIZE + 1 || i+len>s->length+1)
printf("不能进行删除!\n");
else
{
int k;
for (k = i - 1+len; k <s->length; k++)
s->str[k -len] = s->str[k];
s->length = s->length -len;
s->str[s->length] = '\0';
}
}


seq *strconcat(seq s1, seq s2)
{
seq *s;
s = (seq *)malloc(sizeof(seq));
int k;
for (k = 0; k < s1.length; k++)
s->str[k] = s1.str[k];
s->length = s1.length;
if (s1.length + s2.length > MAXSIZE)
{
for (k = 0; k + s->length + 1 < MAXSIZE; k++)
s->str[s->length + k] = s2.str[k];
s->length = MAXSIZE;
s->str[s->length] = '\0';
}
else
{
for (k = 0; k < s2.length; k++)
s->str[s->length + k] = s2.str[k];
s->length = s1.length+s2.length;
s->str[s->length] = '\0';
}
return s;
}


seq *substring(seq s, int i, int len)
{
seq *t;
t = (seq *)malloc(sizeof(seq));
if (i<1 || i>MAXSIZE + 1 ||i+len-1 > MAXSIZE)
printf("没有这样的字串!\n");
else
{
int k;
for (k = 0; k < len; k++)
t->str[k] = s.str[k+i-1];
t->length =len;
t->str[t->length] = '\0';
}
return t;
}


void display(seq S)
{
int i;
for (i = 0; i < S.length; i++)
printf("%5c", S.str[i]);
putchar('\n');
}


void main()
{
seq *s;
s = (seq *)malloc(sizeof(seq));
seq *t;
t = (seq *)malloc(sizeof(seq));
s->str[0] = 'A';
s->str[1] = 'B';
t->str[0] = 'C';
t->str[1] = 'D';
s->length = 2;
t->length = 2;
display(*s);
display(*t);
strinsert(s, 3, *t);
display(*s);
strinsert(s, 3, *s);
display(*s);
strdele(s, 3, 3);
display(*s);
s = strconcat(*s, *t);
display(*s);
t = substring(*s, 2, 3);
display(*t);
}
在C语言中,顺序串通常是指通过字符数组来表示的,每个元素都是单个字符。为了用`malloc`函数为其分配存储空间,首先需要确定所需的内存大小,一般是一个整数n,用于存放字符串加上一个额外的终止符'\0'。以下是创建空顺序串以及输入字符串并计算长度的基本步骤: 1. 定义顺序串结构体: ```c typedef struct { char* data; // 存储字符串的指针 int length; // 字符串的实际长度(不包括终止符) } SequenceString; ``` 2. 分配存储空间: ```c void initSequenceString(SequenceString* s) { if (s != NULL) { s->data = (char*)malloc(sizeof(char) * 1); // 初始预留一个位置存放'\0' s->length = 0; // 初始化长度为0 } else { printf("Error: Invalid sequence string pointer.\n"); } } ``` 注意:这里仅分配了一个位置,实际需要的长度应在读入字符串后更新。 3. 输入字符串和计算长度: ```c void inputAndCalculateLength(SequenceString* s, const char* prompt) { if (s != NULL) { char input[100]; // 假设最多允许输入99个字符,包括'\0' fgets(input, sizeof(input), stdin); // 从标准输入读取 input[strlen(input) - 1] = '\0'; // 移除换行符 s->data = (char*)realloc(s->data, sizeof(char) * (s->length + strlen(input))); // 调整内存大小以容纳新输入 strcpy(s->data + s->length, input); // 将输入复制到已有的内存区域 s->length += strlen(input); // 更新长度 } else { printf("Error: Invalid sequence string pointer.\n"); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值