空串:长度为0的串

空格串:由一个或多个空格组成的串

串常用的3种机内表示方法:

定长顺序存储表示

用一组地址连续的存储单元存储串的字符序列,每一个串变量都有一个固定长度的存储区,可用定长数组来描述。

#define MAXLEN 255

typedef unsigned char Sstring[MAXLEN+];/*0号单元存放串的长度*/

1.串连接

当串s1,s2连接后的结果串t超过了定长MAXLEN时,即s1[0]+s2[0]>MAXLEN,输出相应的信息

void Concat(Sstring t,Sstring s1,Sstring s2)
{/*将s1串和s2串连接后存入t串中*/
int i,j;
int m,n;
m = s1[],n = s2[];
if(m + n > MANXLEN)
printf("两串连接后超过串的定长!\n");
else{
for(i = ;i <= m;i++) t[i] = s1[i];
for(j = ;j <= n;j++) t[i+j] = s2[j];
t[] = m + n; /*将两串连接后的长度存至t[0]中*/
}
}

2.求子串

设子串的起始位置为pos,子串的长度为len

当pos<1或pos>s[0]时,子串位置非法;

当len<0或len>s[0]-pos+1时,子串长度非法。

void SubString(Sstring sub,Sstring s,int pos,int len)
{/*将s中序号pos起len个字符复制到sub中*/
int i;
if(pos<||pos>s[]||len<||len>s[]-pos+)
printf("子串的开始位置或长度错误!\n");
else{
for(i = ;i <= len; i++)
sub[i] = s[i+pos-];
sub[] = len;
}
}

堆分配存储表示:

仍用一组地址连续的存储单元存放串的字符序列,但每个串的存储空间是在程序执行过程中动态分配而得。

堆空间:存放所有串可利用的空间

heap[MAXSIZE]表示堆空间,free指向heap中未分配区域的开始地址,初始化为0

/*====堆分配存储====*/
typedef struct{
char *ch; //串的起始地址
int len; //串的长度
} HSt

1.串连接

void Concat(HString * t,HString * s1,HString * s2)
{/*将s1,s2连接后,存入t串,返回t串*/
int i;
if(t->ch) free(t->ch);//如果串t已存在,先释放掉旧空间
if(!(t->ch=(char *)malloc((s1->len+s2->len)*sizeof(char))))
printf("溢出错误\n");//分配空间失败
else{
for(i=;i<s1->len;i++)
t->ch[i]=s1->ch[i];
for(i=;i<s2->len;i++)
t->ch[i+s1->len]=s2->ch[i];
t->len=s1->len+s2->len;
}
}

2.求子串

void SubString(HString * sub,HString * s,int pos,int len)
{//将s中从pos个位置起的len个字符复制到sub中
int i;
if(pos<||pos>=s->len||len<||len>s->len-pos+)
printf("子串的开始位置或长度错误!\n");
if(sub->ch) free(t->ch);//如果串t已存在,释放旧空间
if(!len) {sub->ch=NULL;sub->len=;}//如果子串为空串
else{
for(i = ;i <len;i++)
sub->ch[i]=s->ch[i+pos];
sub->len=len;
}
}

串的块链存储表示:

可采用链表方式存储串值

#define CHUNKSIZE 80
typedef struct Chunk{
char ch[CHUNKSIZE];
struct Chunk * next;
}Chunk;
typedef struct {
Chunk * head, * tail;
int len;
}LString;

模式匹配:

简单的模式匹配:时间复杂度O(n×m) 效率低,时间主要浪费在指针的回溯上

着重来讲一下

KMP:主要消除了主串指示器变量i的回溯,时间复杂度为O(m+n)

数据结构——串(KMP)的更多相关文章

  1. 基础数据结构-串-KMP算法

    KMP算法用于模式串字符匹配,因为没有提前预习,上课时听得云里雾里,后来回去看了一晚上,翻了一些网上的讲解才理解了.我简单讲一下,我们在一串字符串A里搜索匹配另一段字符串B时,思路最简单方法的就是从第 ...

  2. 数据结构- 串的模式匹配算法:BF和 KMP算法

      数据结构- 串的模式匹配算法:BF和 KMP算法  Brute-Force算法的思想 1.BF(Brute-Force)算法 Brute-Force算法的基本思想是: 1) 从目标串s 的第一个字 ...

  3. [从今天开始修炼数据结构]串、KMP模式匹配算法

    [从今天开始修炼数据结构]基本概念 [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList [从今天开始修炼数据结构]栈.斐波那契数列.逆波兰四则运 ...

  4. 浅谈数据结构之KMP(串中的模式匹配算法)

    KMP算法是一种模式匹配算法的改进版,其通过减少匹配的次数以及使主串不回朔来减少字符串匹配的次数,从而较少算法的相应代价,但是,事件万物是普遍归中的,KMP算法的有效性也是有一定的局限的,我将在本文的 ...

  5. 数据结构(三)串---KMP模式匹配算法实现及优化

    KMP算法实现 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include ...

  6. 数据结构(三)串---KMP模式匹配算法之获取next数组

    (一)获取模式串T的next数组值 1.回顾 我们所知道的KMP算法next数组的作用 next[j]表示当前模式串T的j下标对目标串S的i值失配时,我们应该使用模式串的下标为next[j]接着去和目 ...

  7. 数据结构(三)串---KMP模式匹配算法

    (一)定义 由于BF模式匹配算法的低效(有太多不必要的回溯和匹配),于是某三个前辈发表了一个模式匹配算法,可以大大避免重复遍历的情况,称之为克努特-莫里斯-普拉特算法,简称KMP算法 (二)KMP算法 ...

  8. 数据结构——串的朴素模式和KMP匹配算法

    一.朴素模式 假设我们要从主串S="goodgoogle"中找到子串T="google"的位置,步骤如下: i表示主串的当前位置下标,j表示子串的当前位置下标, ...

  9. 【数据结构】KMP算法

    我还是不太懂... 转2篇大神的解释    1>https://www.cnblogs.com/yjiyjige/p/3263858.html     2>https://blog.csd ...

随机推荐

  1. HI3518EV200+AR0130开发板烧录uboot、kernel、rootfs及其参数配置

    分区名 分区大小 起始地址 截至地址bootloader:1M 0x00000000 0x00100000kernel: 3M 0x00100000 0x00400000rootfs: 12M 0x0 ...

  2. layui layui.open弹窗后按enter键不停弹窗问题的解决

    问题描述:layui.open弹窗后,点击enter键会不停弹窗,背景颜色变得越来越深 解决办法:1.使用回调函数让按钮失去焦点 var info = layer.open({ type: 2 , t ...

  3. linux的使用以及linux服务器应用的部署

    一.Linux(rehat.centos.ubuntu...)基础知识 上午: putty软件连接linux服务器: [root @ foundation2   ~ ]         # 用户名   ...

  4. Unity 3D中的阴影设置

    在Unity 3D中,经常需要用到光照阴影,即Directional Light的Shadow,Shadow分为Hard Shadow和Soft Shadow.区别是Soft Shadow的阴影边缘比 ...

  5. 服务器对接码云webhooks

    服务安装git php代码(外网必须可以访问) <?php //本地路径滚adminasdfdasfasdf $file = "/wwwroot/webhooksLog.txt&quo ...

  6. A记录、CNAME和URL转发区别

    我们在做域名解析时,尤其是很多虚拟主机,大都会使用到CNAME解析,独立主机.VPS则用A记录较多,而URL转发则会在更换域名时用到,从设置效果来看,都是“解析”到一个“其它”URL地址,而实际上它们 ...

  7. DiscuzX2.5,X3.0,X3.1,X3.2完整目录结构【模板目录template】

    /template/default/common  公共模板目录全局加载 block_forumtree.htm  DIY论坛树形列表模块 block_thread.htm  DIY帖子模块调用文件 ...

  8. 更改/var/log/messages默认权限

    问题描述: 操作系统:redhat 6.5 因为开发人员和运维人员平时在应用出现bug时,会需要看/var/log/message日志,但是默认权限为600,因此除了root用户都无法读取,现需要把每 ...

  9. glide 长方形图片显示圆角问题

    目前业务是RecyclerView嵌套RecyclerView,子RecyclerView里面显示图片,图片显示方式又分为 多图和单图显示方式(这个是已经调试好的效果) 测试显示结果只有单张图片不显示 ...

  10. 2018秋寒假作业6—PTA编程总结3

    1.实验代码 7-1 抓老鼠啊~亏了还是赚了? (20 分) 某地老鼠成灾,现悬赏抓老鼠,每抓到一只奖励10元,于是开始跟老鼠斗智斗勇:每天在墙角可选择以下三个操作:放置一个带有一块奶酪的捕鼠夹(T) ...