数据结构---串(赋值,求子串,比较,定位)
目录
一.初始化
顺序表中串的存储
串的链式存储
二.赋值操作:将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;
}
以上代码如有错误,请大佬们赐教!!💖💖感谢到大佬们指出错误
相关文章:

数据结构---串(赋值,求子串,比较,定位)
目录 一.初始化 顺序表中串的存储 串的链式存储 二.赋值操作:将str赋值给S 链式表 顺序表 三.复制操作:将chars复制到str中 链式表 顺序表 四.判空操作 链式表 顺序表 五.清空操作 六.串联结 链式表 顺序表 七.求子串 链式表 顺序表…...

WPF CommunityToolkit.Mvvm
文章目录 前言ToolkitNuget安装简单使用SetProperty,通知更新RealyCommandCanExecute 新功能,代码生成器ObservablePropertyNotifyCanExecuteChangedForRelayCommand其他功能对应关系 NotifyPropertyChangedFor 前言 CommunityToolkit.Mvvm(…...

Vue开发中如何解决国际化语言切换问题
Vue开发中如何解决国际化语言切换问题 引言: 在如今的全球化时代,应用程序的国际化变得越来越重要。为了让不同地区的用户能够更好地使用应用程序,我们需要对内容进行本地化,以适应不同语言和文化环境。对于使用Vue进行开发的应用…...

基于springboot+vue的流动人口登记系统(前后端分离)
博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容:毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…...

Stable Diffusion的使用以及各种资源
Stable Diffsuion资源目录 SD简述sd安装模型下载关键词,描述语句插件管理controlNet自己训练模型 SD简述 Stable Diffusion是2022年发布的深度学习文本到图像生成模型。它主要用于根据文本的描述产生详细图像,尽管它也可以应用于其他任务,如…...
Redis 分布式锁的实现方式
一般来说,在对数据进行“加锁”时,程序首先需要通过获取(acquire)锁来得到对数据排他性访问的能力,然后才能对数据执行一系列操作,最后还要将锁释放(release)给其他程序。 对于能够…...

VMware上搭建的虚拟机突然本地无法连接服务器
长时间没有使用VMware 虚拟机了,今天突然登录上去,启动虚拟服务器后发现本地等不了了, 经过排查发现是开启了:VirtualBox Host-Only Network 关闭之后就本机就可以直连服务器了...

JDBC回顾
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 JDBC回顾 前言一、JDBC1.JDBC是什么?2.如何使用?(1)注册驱动(2)获取连接(3)操作…...
mq 消息队列 mqtt emqx ActiveMQ RabbitMQ RocketMQ
省流: 十几年前,淘宝的notify,借鉴ActiveMQ。京东的ActiveMQ集群几百台,后面改成JMQ。 Linkedin的kafka,因为是scala,国内很多人不熟。淘宝的人把kafka用java写了一遍,取名metaq,后…...
沃尔玛卖家必看!解决订单被Kan、Feng号问题的终极方案!
近期有很多沃尔玛卖家和工作室联系到我提到说在沃尔玛平台上下单,买家号出现副款义常订单被k掉,是什么原因、我们该如何去解决呢? 以下是一些可能导至你的测评订单被k单的原因: 1.技术问题:有时,网站或系…...

浅谈日常使用的 Docker 底层原理-三大底座
适合的读者,对Docker有过简单了解的朋友,想要进一步了解Docker容器的朋友。 前言 回想我这两年,一直都是在使用 Docker,看过的视频、拜读过的博客,大都是在介绍 Docker 的由来、使用、优点和发展趋势,但对…...
前端面试:【DOM】编织网页的魔法
嘿,亲爱的代码魔法师!在JavaScript的奇幻世界里,有一项强大的技能,那就是DOM操作。DOM(文档对象模型)操作允许你选择、修改和创建网页元素,就像是在编织一个魔法的网页。 1. 什么是DOMÿ…...

基于MATLAB开发AUTOSAR软件应用层Code mapping专题-part 2 Inport和Outports 标签页介绍
上篇我们介绍了Function页的内容,这篇我们介绍Inports和Outports页的内容,这里我们再次强调一个概念,code mapping是以simulink的角度去看的,就是先要在模型中建立simulink模块,在code mapping里映射他要对应的autosar的元素,之后生成代码时的c语言的名字是以Autosar的元…...

第9步---MySQL的索引和存储引擎
第9步---MySQL的索引和存储引擎 1.索引 1.1分类 索引可以快速的找出具有特定值的行。不用从头开始进行寻找了。 类别 hash和btree hash 根据字段值生生成一个hash的值 快速的进行定位到对应的行的值 可能会出现相同的值,找到对应的空间会出现对应的值 btree树…...
Numpy入门(3)—线性代数
线性代数 线性代数(如矩阵乘法、矩阵分解、行列式以及其他方阵数学等)是任何数组库的重要组成部分,NumPy中实现了线性代数中常用的各种操作,并形成了numpy.linalg线性代数相关的模块。本节主要介绍如下函数: diag&am…...
php的openssl_encrypt是不是自动做了PKCS5Padding?
在PHP中,openssl_encrypt函数默认使用的是PKCS7填充(不是PKCS5填充)。PKCS7填充实际上是PKCS5填充的扩展,用于对不同块大小的数据进行填充。 当你使用openssl_encrypt函数进行加密时,如果你没有显式指定填充模式和填充…...
在本地创建repository及上传至github
文章目录 本地管理设定git的用户名与邮箱初始化添加修改提交修改设定分支问题一:error: insufficient permission for adding an object... 数据同步创建SSH keys创建并关联远程仓库上传改动至github问题二:Failed to connect to github.com port 443: Connection timed out问题…...

情人节特别定制:多种语言编写动态爱心网页(附完整代码)
写在前面案例1:HTML Three.js库案例2:HTML CSS JavaScript案例3:Python环境 Flask框架结语 写在前面 随着七夕节的临近,许多人都在寻找独特而令人难忘的方式来表达爱意。在这个数字时代,结合创意和技术࿰…...

Docker mysql主从同步安装
1. 构建master实例 docker run -p 3307:3306 --name mysql-master \ -v /mydata/mysql-master/log:/var/log/mysql \ -v /mydata/mysql-master/data:/var/lib/mysql \ -v /mydata/mysql-master/conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORDroot \ -d mysql:5.7 2. 构建master配置…...
docker update 命令
docker update 更新一个或多个容器的配置。官方文档 用法 $ docker update [OPTIONS] CONTAINER [CONTAINER...]请参阅选项部分OPTIONS,了解此命令可用的概述。 描述 该docker update命令动态更新容器配置。您可以使用此命令来防止容器消耗 Docker 主机的过多资…...

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
uniapp 对接腾讯云IM群组成员管理(增删改查)
UniApp 实战:腾讯云IM群组成员管理(增删改查) 一、前言 在社交类App开发中,群组成员管理是核心功能之一。本文将基于UniApp框架,结合腾讯云IM SDK,详细讲解如何实现群组成员的增删改查全流程。 权限校验…...

.Net框架,除了EF还有很多很多......
文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...
2024年赣州旅游投资集团社会招聘笔试真
2024年赣州旅游投资集团社会招聘笔试真 题 ( 满 分 1 0 0 分 时 间 1 2 0 分 钟 ) 一、单选题(每题只有一个正确答案,答错、不答或多答均不得分) 1.纪要的特点不包括()。 A.概括重点 B.指导传达 C. 客观纪实 D.有言必录 【答案】: D 2.1864年,()预言了电磁波的存在,并指出…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...

Vue2 第一节_Vue2上手_插值表达式{{}}_访问数据和修改数据_Vue开发者工具
文章目录 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染2. 插值表达式{{}}3. 访问数据和修改数据4. vue响应式5. Vue开发者工具--方便调试 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染 准备容器引包创建Vue实例 new Vue()指定配置项 ->渲染数据 准备一个容器,例如: …...

微信小程序 - 手机震动
一、界面 <button type"primary" bindtap"shortVibrate">短震动</button> <button type"primary" bindtap"longVibrate">长震动</button> 二、js逻辑代码 注:文档 https://developers.weixin.qq…...

跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...
基于matlab策略迭代和值迭代法的动态规划
经典的基于策略迭代和值迭代法的动态规划matlab代码,实现机器人的最优运输 Dynamic-Programming-master/Environment.pdf , 104724 Dynamic-Programming-master/README.md , 506 Dynamic-Programming-master/generalizedPolicyIteration.m , 1970 Dynamic-Programm…...
Android第十三次面试总结(四大 组件基础)
Activity生命周期和四大启动模式详解 一、Activity 生命周期 Activity 的生命周期由一系列回调方法组成,用于管理其创建、可见性、焦点和销毁过程。以下是核心方法及其调用时机: onCreate() 调用时机:Activity 首次创建时调用。…...