2021-09-16

这篇博客详细介绍了如何使用C++实现字符串的基本操作,包括顺序存储结构、初始化、赋值、复制、判断空字符串、比较、获取长度、子串提取、拼接和查找。通过示例代码展示了这些操作的具体实现,适合C++初学者学习字符串处理。

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

数据结构串的顺序存储基本方法实现

#include <cstdio>
#include <cstring>
#include <algorithm>
#define MAXLEN 255

struct SString
{
    char * ch;
    int length;
};

void StrPrint(const SString &T);

bool InitStr(SString &T){
    T.length = 0;
    T.ch = (char *)malloc(sizeof(char) * MAXLEN);
    if (T.ch !=NULL)
    {
        printf("malloc() 申请成功\n");
        return true;
    }else
    {
        printf("malloc() 申请失败\n");
        return false;
    }
}

bool StrAssign(SString &T,const char * c){
    T.length = 0;//赋值就是要重置 全部内容 要从下标为0 开始++
    while (*c!='\0')
    {
        T.ch[++T.length] = *c;
        c = c + sizeof(char);
    }
    return 0;
}

bool StrCopy(SString &T,SString S){
    for (int i = 1; i <= S.length; i++)
    {
        T.ch[i] = S.ch[i];
    }
    T.length = S.length;
    return 0;
}

bool StrEmpty(SString S){
    if (S.length == 0)
    {
        return true;
    }else
    {
        return false;
    }
}

int StrCompare(SString S,SString T){
    int i;
    for (i = 1; i <= S.length && i<=T.length; i++)
    {
        if (S.ch[i]!=T.ch[i])
        {
            return S.ch[i] - T.ch[i];
        }
    }
    return S.length - T.length; 
}

int StrLength(SString S){
    return S.length;
}

bool SubString(SString &Sub,SString S,int pos,int len){
    Sub.length = 0;
    for (int i = pos; i <= pos + len -1; i++)
    {
        Sub.ch[++Sub.length] = S.ch[pos+Sub.length];
    }
    return true;
}

bool Concat(SString &T,SString S1,SString S2){
    for (int i = 1; i <= S1.length + S2.length; i++)
    {
        if (i <= S1.length)
        {
            T.ch[++T.length] = S1.ch[i];
        }else
        {
            T.ch[++T.length] = S2.ch[i-S1.length];
        }
    
    }
    return true;
}

int Index(SString S, SString T){
    if (T.length > S.length)
    {
        return 0;
    }
    SString sub;
    InitStr(sub);
    int i=1,n=S.length,m=T.length;
    while (i<=n-m+1)
    {
        printf("i = %d  m = %d",i,m);
        SubString(sub,S,i,m);
        printf("sub = ");
        StrPrint(sub);
        printf("StrCompare(sub,T) = %d\n",StrCompare(sub,T));
        if (StrCompare(sub,T)!=0)
        {
            ++i;
        }else
        {
            return i;
        }
    }
    return 0;
}

void StrPrint(const SString &T){
    for (int i = 1; i <= T.length; i++)
    {
        printf("%c",T.ch[i]);
    }
    printf("\n");
}

int main(){
    SString Q;
    SString T;
    SString Sub;
    InitStr(Q);
    InitStr(T);
    InitStr(Sub);
    const char * temp = "woshizhendeai shangni";
    const char * temp2 = "ni";
    StrAssign(Q,temp);
    StrAssign(T,temp2);
    StrPrint(Q);
    StrPrint(T);
    Concat(Sub,Q,T);
    StrPrint(Sub);
    printf("%d\n",Index(Q,T));

    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值