#include<stdio.h>

 int strLength(char* s)//求字符长度
{
int i=;
while(s[i]!=NULL)
{
i++;
}
return i;
} int* getNext(char* p)
{
int length=strLength(p);
int* next=(int *)calloc(length,sizeof(int));
next[] = -;
int j = ;
int k = -;
while (j < length - )
{
if (k == - || p[j] == p[k])
{
if (p[++j] == p[++k])
{ // 当两个字符相等时要跳过 next[j] = next[k];
}
else
{
next[j] = k;
}
}
else
{
k = next[k];
}
}
return next;
} int KMP(char* t,char* p)
{
int i = ; // 主串的位置
int j = ; // 模式串的位置
int lengtht=strLength(t);
int lengthp=strLength(p);
int *next=getNext(p); while (i < lengtht && j < lengthp)
{
if (j == - || t[i] == p[j])
{ // 当j为-1时,要移动的是i,当然j也要归0
i++;
j++;
}
else
{
// i不需要回溯了
// i = i - j + 1;
j = next[j]; // j回到指定位置
}
} if (j == lengthp)
{
return i - j;
}
else
{
return -;
}
} void strCopy(char *des,char *src)//字符串拷贝
{
int i=;
while(src[i]!=NULL)
{
des[i]=src[i];
i++;
}
} void destroyStr(char *des)//字符串删除
{
free(des);
} bool strEmpty(char *des)//判断字符串是否为空
{
if(des[]==NULL)
{
return true;
}
else
{
return false;
}
} int strCompare(char *s1,char *s2)//字符串比较
{
int flag;
for(int i=;;i++)
{
if(s1[i]==NULL&&s2[i]!=NULL)
{
flag=-;
break;
}
else if(s1[i]!=NULL&&s2[i]==NULL)
{
flag=;
break;
}
else if(s1[i]==NULL&&s2[i]==NULL)
{
flag=;
break;
}
}
return flag;
} char* strConcat(char* s1,char* s2)//字符串连接函数
{
int length1,length2;
length1=strLength(s1);
length2=strLength(s2);
char *s=(char *)malloc(sizeof(char)*(length1+length2));
int i=;
while(s1[i]!=NULL)
{
s[i]=s1[i];
i++;
}
int j=;
while(s2[j]!=NULL)
{
s[i]=s2[j];
i++;
j++;
}
return s;
} char* strSub(char* s,int pos,int length)//将str串从pos位置开始复制到subStr中
{
char *sub=(char *)malloc(sizeof(char)*length);//建议此处将malloc函数改为calloc函数;calloc在动态分配完内存后,自动初始化该内存空间为零,而malloc不初始化,里边数据是随机的垃圾数据。
int i=pos;
int count=;
while(count<=length)
{
sub[count]=s[i];
i++;
count++;
}
return sub;
} char* strReplace(char* s,char* sub,char* replaceStr)//字符串替换
{
int end;
char* temp1;
char* temp2;
int begin=;
int subLength=strlen(sub);
end=KMP(s,sub);
while(end!=-)
{
temp1=strSub(s,begin,end-begin);
temp2=strSub(s,end+subLength,strlen(s)-(end+subLength));
s=strcat(temp1,replaceStr);
s=strcat(s,temp2);
end=KMP(s,sub);
}
return s;
}

不利用C语言库函数,实现字符串相关函数的更多相关文章

  1. C语言复习:字符串和一级指针

    字符串基本操作 字符数组初始化方法 int main() {     //1 {}号法 初始化列表     //数组初始化有2种方法 默认元素个数.指定元素个数     char buf1[] = { ...

  2. C语言处理json字符串

    JSON语法说明 先来看一个简单的JSON 1 { 2 "stars": [ 3 { 4 "name": "Faye", 5 "a ...

  3. C语言库函数大全及应用实例十四

    原文:C语言库函数大全及应用实例十四                                       [编程资料]C语言库函数大全及应用实例十四 函数名: strset 功 能: 将一个串 ...

  4. C语言库函数大全及应用实例十三

    原文:C语言库函数大全及应用实例十三                                          [编程资料]C语言库函数大全及应用实例十三 函数名: stat 功 能: 读取打 ...

  5. C语言库函数大全及应用实例十二

    原文:C语言库函数大全及应用实例十二                                          [编程资料]C语言库函数大全及应用实例十二 函数名: setrgbpalette ...

  6. C语言库函数大全及应用实例九

    原文:C语言库函数大全及应用实例九                                                [编程资料]C语言库函数大全及应用实例九 函数名: mktemp 功 ...

  7. C语言库函数大全及应用实例八

    原文:C语言库函数大全及应用实例八                                            [编程资料]C语言库函数大全及应用实例八 函数名: kbhit 功 能: 检查 ...

  8. C语言库函数大全及应用实例五

    原文:C语言库函数大全及应用实例五                                                 [编程资料]C语言库函数大全及应用实例五 函数名: getcurdi ...

  9. C语言库函数大全及应用实例六

    原文:C语言库函数大全及应用实例六                                              [编程资料]C语言库函数大全及应用实例六 函数名: getlinesett ...

随机推荐

  1. Layers Of Caffe

    本文试图描述构建一个网络结构的layers,可以用prototxt脚本直接写,也可以用python接口实现. 最简单的神经网络包含但不限于以下四部分: 数据层(Data): Data.ImageDat ...

  2. Anaconda创建caffe和tensorflow共存环境

    一.前言 安装环境: Anaconda Ubuntu 二.安装步骤 我们分几步进行,anconda的安装和使用方法就不讲解了.我们直接安装caffe和tensorflow. 1.创建虚拟环境 我们先创 ...

  3. WinHex数据恢复笔记(一)

    WinHex数据恢复功能强大,可以从硬件簇上扇区进行数据扫描恢复.首先对winhex的各个功能介绍.之后对实例记录一个Word文档删除后进行恢复. 1.WinHex数据恢复软件的编辑区输入与其他普通文 ...

  4. cf round546 cde

    第一题会卡一下同时用set和cin.. 其他的注意下矩阵对角线下标的应用即可 #include<bits/stdc++.h> using namespace std; #define ma ...

  5. Git使用四:查看工作状态和历史提交

    查看当前的工作状态:git status On branch master:现在位于master分支里面nothing to commit, working tree clean:没有需要提交的文件, ...

  6. mybatis初始化过程

    mybatis初始化如下: //加载配置文件InputStream resourceAsStream = Resources.getResourceAsStream("testMybatis ...

  7. Python之yield简明详解

    yield在Python中被称之为生成器(只能在函数中使用),他的作用是将函数中每次执行的结果以类似元组的形式保存起来一遍后续使用. 什么是生成器? 通过列表生成式,我们可以直接创建一个列表.但是,受 ...

  8. servlet在地址栏填写参数

    单个参数:以"?"开头+参数名+"="符号+参数值 例如 https://i.cnblogs.com/EditPosts.aspx?opt=1 多个参数:以&q ...

  9. PAT Basic 1069. 微博转发抽奖(20)

    小明PAT考了满分,高兴之余决定发起微博转发抽奖活动,从转发的网友中按顺序每隔N个人就发出一个红包.请你编写程序帮助他确定中奖名单. 输入格式: 输入第一行给出三个正整数M(<= 1000).N ...

  10. 各厂商服务器存储默认管理口登录信息(默认IP、用户名、密码)收集

    666:https://blog.csdn.net/xiezuoyong/article/details/84997917