数据结构---串(赋值,求子串,比较,定位)

目录

一.初始化

顺序表中串的存储 

串的链式存储

二.赋值操作:将str赋值给S

链式表

顺序表

三.复制操作:将chars复制到str中

链式表

顺序表

四.判空操作

链式表

顺序表

五.清空操作

六.串联结

链式表

顺序表

七.求子串

链式表

顺序表

八. 比较串的大小

链式表

顺序表

九.定位操作

链式表

顺序表


一.初始化

顺序表中串的存储 

#define MaxLen 255
typedef struct{char ch[MaxLen];//静态数组,系统自动回收int length;}SString;typedef struct{char *ch;int length;}HString;HString S;
S.ch=(char*)malloc(MaxLen*sizeof(char));//在堆区分配存储空间,所以需要free手动回收
S.length=0;

串的链式存储

typedef struct StringNode{char ch;//一个字符占一个字节struct StringNode *next;//占4个字节/8个字节}StringNode,*String;
//以上定义的结构体类型存储密度低,可以采用以下方案定义结构体typedef struct StringNode{char *ch;//或一个结点存放更多字符struct StringNode *next;
}StringNode,*String;

二.赋值操作:将str赋值给S

链式表

void StrAssign(const StringNode* str, char** S) {int len = 0;const StringNode* currentNode = str;// 计算字符串长度while (currentNode != NULL && currentNode->ch != '\0') {len++;currentNode = currentNode->next;}*S = (char*)malloc((len + 1) * sizeof(char)); // 分配空间,要考虑'\0'所以长度加1int i = 0;
//将 currentNode 指向 str,我们可以从链表的头部开始逐个访问节点,并依次处理每个节点的字符currentNode = str;// 复制字符到新的字符串里while (currentNode != NULL && currentNode->ch != '\0') {(*S)[i] = currentNode->ch;i++;currentNode = currentNode->next;}(*S)[i] = '\0'; // 在新的字符串末尾添加'\0'表示结束
}

顺序表

void StrAssign(SString S, SString& sub) {int length = 0;while (S.ch[length] != '\0') {sub.ch[length] = S.ch[length];length++;}sub.ch[length] = '\0';
}

三.复制操作:将chars复制到str中

链式表

void StrCopy(StringNode* str, const char* chars) {int len = strlen(chars);int i;for (i = 0; i < len; i++) {str->ch = chars[i];if (i < len - 1) {str->next = (StringNode*)malloc(sizeof(StringNode));// 若字符串还没有复制完毕则手动扩展空间str->next->ch = '\0'; // 将下一个节点的 ch 字段设置为空字符str = str->next;}}str->next = NULL;
}

顺序表

和赋值操作相同

void StrCopy(SString S, SString& sub) {int length = 0;while (S.ch[length] != '\0') {sub.ch[length] = S.ch[length];length++;}sub.ch[length] = '\0';
}

四.判空操作

链式表

bool StrEmpty(String str)
{if(str->ch[0]=='\0')return true;elsereturn false;}

顺序表

bool StrEmpty(SString S) {if (S.ch[0] == '\0')return true;elsereturn false;
}

五.清空操作

void StrClear(StringNode* str)
{while(str!=NULL){free(str);str=str->next;}
}

六.串联结

链式表

void Concat(StringNode* str, char* s1, char* s2) {int len1 = strlen(s1);int len2 = strlen(s2);// 创建一个新的结点用于存储连接后的字符串StringNode* newNode = (StringNode*)malloc(sizeof(StringNode));newNode->ch = (char*)malloc((len1 + len2 + 1) * sizeof(char)); // 加1是为了存放字符串结束符 '\0'newNode->next = NULL;// 连接字符串并保存到新结点的ch字段strcpy(newNode->ch, s1);strcat(newNode->ch, s2);// 找到链表末尾并将新结点连接到其后while (str->next != NULL) {str = str->next;}str->next = newNode;
}

顺序表

void Concat(SString& sub, SString S, SString T) {int i = 0;// 复制字符串 S 到 subwhile (S.ch[i] != '\0') {sub.ch[i] = S.ch[i];i++;}// 复制字符串 T 到 subint j = 0;while (T.ch[j] != '\0') {sub.ch[i] = T.ch[j];i++;j++;}sub.ch[i] = '\0'; // 添加字符串结束符
}

七.求子串

链式表

void Insert(StringNode** str, char ch) {StringNode* newNode = (StringNode*)malloc(sizeof(StringNode));newNode->ch = ch;newNode->next = NULL;if (*str == NULL) {*str = newNode;return;}StringNode* currentNode = *str;while (currentNode != NULL) {currentNode = currentNode->next;}currentNode->next = newNode;
}StringNode* SubString(StringNode* str, int pos, int len) {StringNode* subStr = NULL;StringNode* currentNode = str;int currentPos = 0;while (currentNode != NULL && currentPos < pos + len) {if (currentPos >= pos) {Insert(&subStr, currentNode->ch);}currentNode = currentNode->next;currentPos++;}return subStr;
}

顺序表

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

八. 比较串的大小

链式表

int getListLength(StringNode* head) {int length = 0;ListNode* current = head;while (current != nullptr) {length++;current = current->next;}return length;
}int compareLinkedListLength(StringNode* list1, StringNode* list2) {int length1 = getListLength(list1);int length2 = getListLength(list2);if (length1 > length2) {return 1;} else if (length1 < length2) {return -1;} else {return 0;}
}

顺序表

若S>T,则返回值>0;若S=T,则返回值=0;若S<T,则返回值<0

int StrCompare(SString S,SString T)
{for(int 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;
}

九.定位操作

链式表

ListNode* locateNode(StringNode* head, int position) {if (position <= 0 || head == nullptr) {return nullptr;}ListNode* current = head;int count = 1;while (current != nullptr && count < position) {current = current->next;count++;}return current;
}

顺序表

若主串S中存在与串T值相同的子串,则返回它在主串S中第一次出现的位置,否则函数值为0

#define MaxLen 255
typedef struct {char ch[MaxLen]; // 静态数组,系统自动回收int length;
} SString;void SubString(SString& sub, SString S, int start, int length) {int i;for (i = 0; i < length; ++i) {sub.ch[i] = S.ch[start + i];}sub.ch[length] = '\0'; // 添加字符串结束符sub.length = length;
}int StrCompare(SString S, SString T) {int i = 0;while (S.ch[i] != '\0' && T.ch[i] != '\0') {if (S.ch[i] != T.ch[i]) {return S.ch[i] - T.ch[i];}i++;}return S.length - T.length;
}int Index(SString S, SString T) {int i = 1, n = S.length, m = T.length; // n, m 分别为字符串 S 和 T 的长度SString sub;while (i <= n - m + 1) {//确保了字符串 T 在字符串 S 中进行匹配时不会越界
//假设 n = 10,m = 3,那么 n - m + 1 = 8
//在循环中,当 i = 9 或 i = 10 时,剩余的字符串 S 的长度已经小于 T 的长度,无法再进行匹配SubString(sub, S, i, m);if (StrCompare(sub, T) != 0)++i;elsereturn i;}return 0;
}

以上代码如有错误,请大佬们赐教!!💖💖感谢到大佬们指出错误

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/47233.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

掌握AI助手的魔法工具:解密Prompt(提示)在AIGC时代的应用「上篇」

在当今的AIGC时代&#xff0c;我们面临着越来越多的人工智能技术和应用。其中一个引人注目的工具就是Prompt&#xff08;提示&#xff09;。它就像是一种魔法&#xff0c;可以让我们与AI助手进行更加互动和有针对性的对话。那么&#xff0c;让我们一起来了解一下Prompt&#xf…

广东灯具3D扫描抄数建模服务3D测绘出图纸三维逆向设计-CASAIM

灯具三维逆向建模是一种将实际物体转换为数字模型的过程。通过逆向工程技术&#xff0c;可以将现有的灯具进行3D扫描&#xff0c;然后利用专业的逆向设计软件将其转换为准确的三维模型。 以下是CASAIM实施灯具三维逆向建模的一般步骤图&#xff1a; 1. 扫描&#xff1a;三维扫…

电商直播大行其道,游戏直播日渐式微:虎牙、斗鱼求变

曾几何时&#xff0c;游戏直播领域格外热闹&#xff0c;一度上演千播大战的火热赛况。如今&#xff0c;游戏直播行业已经基本形成了虎牙、斗鱼两强相对的市场格局。随着游戏直播行业告别高增长阶段&#xff0c;逐渐进入存量竞争时代&#xff0c;行业竞争也变得愈发激烈。即便是…

Java面试题--设计模式

一、Java 中有几种设计模式&#xff1f; Java 中一般认为有 23 种设计模式 分为三大类&#xff1a; 1. 创建型模式 5 种 ① 工厂方法模式 ② 抽象工厂模式 ③ 单例模式 ④ 建造者模式 ⑤ 原型模式 2. 结构型模式 7 种 ① 适配器模式 ② 装饰器模式 ③ 代理模式 ④ 外观模式 …

SSL证书如何使用?SSL保障通信安全

由于SSL技术已建立到所有主要的浏览器和WEB服务器程序中&#xff0c;因此&#xff0c;仅需安装数字证书或服务器证书就可以激活功能了。SSL证书主要是服务于HTTPS&#xff0c;部署证书后&#xff0c;网站链接就由HTTP开头变为HTTPS。 SSL安全证书主要用于发送安全电子邮件、访…

动态规划之0-1背包问题

动态规划之0-1背包问题 文章目录 动态规划之0-1背包问题一、先给出代码二、讲解第一步&#xff1a;初始化第二步&#xff1a;动态规划&#xff0c;填表第三步&#xff1a;回溯&#xff0c;找到选择方案总结 三、进阶&#xff08;用一维数组解决问题&#xff09; 一、先给出代码…

社交工程和钓鱼攻击防范: 分析针对人类心理和社交工程的攻击技术,并介绍预防这些攻击的方法

第一章&#xff1a;引言 随着科技的不断进步&#xff0c;网络安全问题愈发凸显。在这个数字化时代&#xff0c;社交工程和钓鱼攻击成为黑客们获取敏感信息的常用手段。这些攻击不是基于技术漏洞&#xff0c;而是利用人类心理弱点来进行。本文将深入探讨社交工程和钓鱼攻击的原…

Flowable学习[一]

一、参考CSDN博主[水中加点糖]的博客[采用springbootflowable快速实现工作流]&#xff0c;文章地址&#xff1a;https://puhaiyang.blog.csdn.net/article/details/79845248&#xff0c;下载其发布在github上的代码 二、本地解压代码&#xff0c;并加载到idea中 三、使用docke…

ubuntu18.04安装远程控制软件ToDest方法,针对官网指令报错情况

有时我们在家办公&#xff0c;需要控制实验室的笔记本&#xff0c;因此好用的远程控制软件会让我们的工作事半功倍&#xff01; 常用的远程控制软件有ToDesk&#xff0c;向日葵&#xff0c;以及TeamViewer&#xff0c;但是为感觉ToDesk更流畅一些&#xff0c;所以这里介绍一下…

C++ 线程池

目录 一、线程池实现原理 二、定义线程池的结构 三、创建线程池实例 四、添加工作的线程的任务函数 五、管理者线程的任务函数 六、往线程池中添加任务 七、获取线程池工作的线程数量与活着的线程数量 八、线程池的销毁 一、线程池实现原理 线程池的组成主要分为3个部…

深入了解Git:介绍及常用命令指南

当今软件开发领域中&#xff0c;版本控制是一个至关重要的概念&#xff0c;而Git作为最流行的分布式版本控制系统&#xff0c;发挥着不可替代的作用。本文将介绍Git的基本概念以及常用命令&#xff0c;帮助你更好地理解和使用这一强大的工具。 Git简介 Git是一种分布式版本管…

从业务层的代码出发,去排查通用框架代码崩溃的问题

目录 1、问题说明 1.1、Release下崩溃&#xff0c;Debug下很难复现 1.2、用Windbg打开dump文件&#xff0c;发现崩溃在通用的框架代码中 2、进一步分析 2.1、使用IDA查看汇编代码尝试寻找崩溃的线索 2.2、在Windbg中查看相关变量的值 2.3、查看最近代码的修改记录&#…

代码随想录day11

20. 有效的括号 ● 力扣题目链接 ● 给定一个只包括 ‘(’&#xff0c;‘)’&#xff0c;‘{’&#xff0c;‘}’&#xff0c;‘[’&#xff0c;‘]’ 的字符串&#xff0c;判断字符串是否有效。 ● 有效字符串需满足&#xff1a; ● 左括号必须用相同类型的右括号闭合。 ● 左…

SAP ABAPG开发屏幕自动生成日期的搜索帮助

代码如下&#xff1a; REPORT z_jason_test_f4 . TABLES: s031. PARAMETER p_spmon TYPE spmon DEFAULT sy-datum0(6) OBLIGATORY. SELECT-OPTIONS s_spmon FOR s031-spmon DEFAULT sy-datum0(6) OBLIGATORY. AT SELECTION-SCREEN ON VALUE-REQUEST…

机器学习使用场景

在计算机系统中&#xff0c;“经验”通常以“数据”的形式存在。因此&#xff0c;机器学习的主要内容&#xff0c;是关于在计算机上从数据中产生Function的算法&#xff0c;这个Function的作用是将将输入映射成合理的输出。例如给Function输入猫的图片&#xff0c;Function能够…

Python面向对象植物大战僵尸

先来一波效果图 来看看如何设计游戏架构 import sysimport pygameclass BaseSprite(pygame.sprite.Sprite):def __init__(self, name):super().__init__()self.image pygame.image.load(name)self.rect self.image.get_rect()class AnimateSprite(BaseSprite):def __init__(…

C++信息学奥赛1131:基因相关性

这段代码的功能是比较两个字符串的相似度&#xff0c;并根据给定的阈值判断是否相似。 解析注释后的代码如下&#xff1a; #include <iostream> #include <string> using namespace std;int main() {double bf; // 定义双精度浮点数变量bf&#xff0c;用于存储阈…

机器学习深度学习——NLP实战(自然语言推断——数据集)

&#x1f468;‍&#x1f393;作者简介&#xff1a;一位即将上大四&#xff0c;正专攻机器学习的保研er &#x1f30c;上期文章&#xff1a;机器学习&&深度学习——NLP实战&#xff08;情感分析模型——textCNN实现&#xff09; &#x1f4da;订阅专栏&#xff1a;机器…

MAC钓鱼并Root权限上线CS并权限维持,以及所有的坑如何解决

本文转载于&#xff1a;https://www.freebuf.com/articles/web/350592.html 作者&#xff1a;文鸯涂鸦智能安全实验室 制作MAC 一、下载工具 首先从github上下载CrossC2。链接&#xff1a;https://github.com/gloxec/CrossC2/releases/tag/v3.1.0。 根据你CS客户端的操作系统选…

python 打印沁园春 雪 居中对齐 文本对齐

以下是python 中使用 DebugInfo 模块居中对齐打印《沁园春・雪》的效果 引入模块 pip install DebugInfopython代码 # -*- coding:UTF-8 -*-# region 引入必要依赖 from DebugInfo.DebugInfo import * # endregion诗文 沁园春 雪 作者: 毛主席 北国风光&#xff0c;千里冰封…