当前位置: 首页 > news >正文

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

目录

一.初始化

顺序表中串的存储 

串的链式存储

二.赋值操作:将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;
}

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

相关文章:

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

目录 一.初始化 顺序表中串的存储 串的链式存储 二.赋值操作&#xff1a;将str赋值给S 链式表 顺序表 三.复制操作&#xff1a;将chars复制到str中 链式表 顺序表 四.判空操作 链式表 顺序表 五.清空操作 六.串联结 链式表 顺序表 七.求子串 链式表 顺序表…...

WPF CommunityToolkit.Mvvm

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

Vue开发中如何解决国际化语言切换问题

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

基于springboot+vue的流动人口登记系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…...

Stable Diffusion的使用以及各种资源

Stable Diffsuion资源目录 SD简述sd安装模型下载关键词&#xff0c;描述语句插件管理controlNet自己训练模型 SD简述 Stable Diffusion是2022年发布的深度学习文本到图像生成模型。它主要用于根据文本的描述产生详细图像&#xff0c;尽管它也可以应用于其他任务&#xff0c;如…...

Redis 分布式锁的实现方式

一般来说&#xff0c;在对数据进行“加锁”时&#xff0c;程序首先需要通过获取&#xff08;acquire&#xff09;锁来得到对数据排他性访问的能力&#xff0c;然后才能对数据执行一系列操作&#xff0c;最后还要将锁释放&#xff08;release&#xff09;给其他程序。 对于能够…...

VMware上搭建的虚拟机突然本地无法连接服务器

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

JDBC回顾

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 JDBC回顾 前言一、JDBC1.JDBC是什么&#xff1f;2.如何使用&#xff1f;&#xff08;1&#xff09;注册驱动&#xff08;2&#xff09;获取连接&#xff08;3&#xff09;操作…...

mq 消息队列 mqtt emqx ActiveMQ RabbitMQ RocketMQ

省流&#xff1a; 十几年前&#xff0c;淘宝的notify&#xff0c;借鉴ActiveMQ。京东的ActiveMQ集群几百台&#xff0c;后面改成JMQ。 Linkedin的kafka&#xff0c;因为是scala&#xff0c;国内很多人不熟。淘宝的人把kafka用java写了一遍&#xff0c;取名metaq&#xff0c;后…...

沃尔玛卖家必看!解决订单被Kan、Feng号问题的终极方案!

近期有很多沃尔玛卖家和工作室联系到我提到说在沃尔玛平台上下单&#xff0c;买家号出现副款义常订单被k掉&#xff0c;是什么原因、我们该如何去解决呢&#xff1f; 以下是一些可能导至你的测评订单被k单的原因&#xff1a; 1.技术问题&#xff1a;有时&#xff0c;网站或系…...

浅谈日常使用的 Docker 底层原理-三大底座

适合的读者&#xff0c;对Docker有过简单了解的朋友&#xff0c;想要进一步了解Docker容器的朋友。 前言 回想我这两年&#xff0c;一直都是在使用 Docker&#xff0c;看过的视频、拜读过的博客&#xff0c;大都是在介绍 Docker 的由来、使用、优点和发展趋势&#xff0c;但对…...

前端面试:【DOM】编织网页的魔法

嘿&#xff0c;亲爱的代码魔法师&#xff01;在JavaScript的奇幻世界里&#xff0c;有一项强大的技能&#xff0c;那就是DOM操作。DOM&#xff08;文档对象模型&#xff09;操作允许你选择、修改和创建网页元素&#xff0c;就像是在编织一个魔法的网页。 1. 什么是DOM&#xff…...

基于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的值 快速的进行定位到对应的行的值 可能会出现相同的值&#xff0c;找到对应的空间会出现对应的值 btree树…...

Numpy入门(3)—线性代数

线性代数 线性代数&#xff08;如矩阵乘法、矩阵分解、行列式以及其他方阵数学等&#xff09;是任何数组库的重要组成部分&#xff0c;NumPy中实现了线性代数中常用的各种操作&#xff0c;并形成了numpy.linalg线性代数相关的模块。本节主要介绍如下函数&#xff1a; diag&am…...

php的openssl_encrypt是不是自动做了PKCS5Padding?

在PHP中&#xff0c;openssl_encrypt函数默认使用的是PKCS7填充&#xff08;不是PKCS5填充&#xff09;。PKCS7填充实际上是PKCS5填充的扩展&#xff0c;用于对不同块大小的数据进行填充。 当你使用openssl_encrypt函数进行加密时&#xff0c;如果你没有显式指定填充模式和填充…...

在本地创建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&#xff1a;HTML Three.js库案例2&#xff1a;HTML CSS JavaScript案例3&#xff1a;Python环境 Flask框架结语 写在前面 随着七夕节的临近&#xff0c;许多人都在寻找独特而令人难忘的方式来表达爱意。在这个数字时代&#xff0c;结合创意和技术&#xff0…...

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&#xff0c;了解此命令可用的概述。 描述 该docker update命令动态更新容器配置。您可以使用此命令来防止容器消耗 Docker 主机的过多资…...

测试微信模版消息推送

进入“开发接口管理”--“公众平台测试账号”&#xff0c;无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息&#xff1a; 关注测试号&#xff1a;扫二维码关注测试号。 发送模版消息&#xff1a; import requests da…...

vscode里如何用git

打开vs终端执行如下&#xff1a; 1 初始化 Git 仓库&#xff08;如果尚未初始化&#xff09; git init 2 添加文件到 Git 仓库 git add . 3 使用 git commit 命令来提交你的更改。确保在提交时加上一个有用的消息。 git commit -m "备注信息" 4 …...

51c自动驾驶~合集58

我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留&#xff0c;CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制&#xff08;CCA-Attention&#xff09;&#xff0c;…...

Python:操作 Excel 折叠

💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...

java调用dll出现unsatisfiedLinkError以及JNA和JNI的区别

UnsatisfiedLinkError 在对接硬件设备中&#xff0c;我们会遇到使用 java 调用 dll文件 的情况&#xff0c;此时大概率出现UnsatisfiedLinkError链接错误&#xff0c;原因可能有如下几种 类名错误包名错误方法名参数错误使用 JNI 协议调用&#xff0c;结果 dll 未实现 JNI 协…...

【第二十一章 SDIO接口(SDIO)】

第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

WordPress插件:AI多语言写作与智能配图、免费AI模型、SEO文章生成

厌倦手动写WordPress文章&#xff1f;AI自动生成&#xff0c;效率提升10倍&#xff01; 支持多语言、自动配图、定时发布&#xff0c;让内容创作更轻松&#xff01; AI内容生成 → 不想每天写文章&#xff1f;AI一键生成高质量内容&#xff01;多语言支持 → 跨境电商必备&am…...

《基于Apache Flink的流处理》笔记

思维导图 1-3 章 4-7章 8-11 章 参考资料 源码&#xff1a; https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...

Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理

引言 Bitmap&#xff08;位图&#xff09;是Android应用内存占用的“头号杀手”。一张1080P&#xff08;1920x1080&#xff09;的图片以ARGB_8888格式加载时&#xff0c;内存占用高达8MB&#xff08;192010804字节&#xff09;。据统计&#xff0c;超过60%的应用OOM崩溃与Bitm…...

JS设计模式(4):观察者模式

JS设计模式(4):观察者模式 一、引入 在开发中&#xff0c;我们经常会遇到这样的场景&#xff1a;一个对象的状态变化需要自动通知其他对象&#xff0c;比如&#xff1a; 电商平台中&#xff0c;商品库存变化时需要通知所有订阅该商品的用户&#xff1b;新闻网站中&#xff0…...