#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. 关闭VirtualBox虚拟机的时钟同步

    原文链接:关闭VirtualBox虚拟机的时钟同步 在VirtualBox的虚拟机上默认虚拟机的时间是会和物理机同步的,但可以通过下面的命令来关闭 1. 首先查看虚拟机列表 VBoxManage li ...

  2. nginx实践(二)之静态资源web服务(浏览器缓存场景)

    配置语法-expires

  3. laravel 更新验证

    public function update(Request $request, User $user) { // 验证规则. $rules = [ 'email' => [ 'nullable ...

  4. kali 局域网嗅探

    1.局域网图片嗅探 工具  arpspoof arpspoof -i eth0 -t 192.1681.10(网卡 目标地址) 192.168.1.1 局域网网关,如果在Windows中可以使用局域网 ...

  5. node.js 框架express有关于router的运用

    1.express 路由入门 const express = require('express'); let server = express(); server.listen(8087); //用户 ...

  6. Nginx详解十六:Nginx场景实践篇之缓存服务

    缓存类型: 服务端缓存 代理缓存 客户端缓存 Nginx代理缓存 配置语法 使用之前需要先定义一个proxy_cache_path配置语法:proxy_cache_path path [levels= ...

  7. 80端口被占用 导致apach无法启动问题

    1.查找是哪个程序占用了80端口 netstat -ano 列出所有进程 观察 “本地地址” 列 找到对应的PID 我这里是4 简单的办法,打开任务管理器,查看PID是4的 是哪个进程. 发现是Sys ...

  8. OpenCV-Python入门教程2-打开摄像头

    一.打开摄像头 import cv2 # 打开摄像头并灰度化显示 capture = cv2.VideoCapture(0) while(True): # 获取一帧 ret, frame = capt ...

  9. Knockout示例:User数据CRUD

    模拟数据user.json. { "page": 0, "rows": 0, "total": 161, "isSuccess&q ...

  10. Centos6中Docker使用中国官方镜像加速

    vi /etc/sysconfig/docker 增加如下内容: other_args="--registry-mirror=https://registry.docker-cn.com&q ...