当前位置: 首页 > 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;
}

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

http://www.lryc.cn/news/134250.html

相关文章:

  • WPF CommunityToolkit.Mvvm
  • Vue开发中如何解决国际化语言切换问题
  • 基于springboot+vue的流动人口登记系统(前后端分离)
  • Stable Diffusion的使用以及各种资源
  • Redis 分布式锁的实现方式
  • VMware上搭建的虚拟机突然本地无法连接服务器
  • JDBC回顾
  • mq 消息队列 mqtt emqx ActiveMQ RabbitMQ RocketMQ
  • 沃尔玛卖家必看!解决订单被Kan、Feng号问题的终极方案!
  • 浅谈日常使用的 Docker 底层原理-三大底座
  • 前端面试:【DOM】编织网页的魔法
  • 基于MATLAB开发AUTOSAR软件应用层Code mapping专题-part 2 Inport和Outports 标签页介绍
  • 第9步---MySQL的索引和存储引擎
  • Numpy入门(3)—线性代数
  • php的openssl_encrypt是不是自动做了PKCS5Padding?
  • 在本地创建repository及上传至github
  • 情人节特别定制:多种语言编写动态爱心网页(附完整代码)
  • Docker mysql主从同步安装
  • docker update 命令
  • 阻塞和挂起的区别和联系
  • 水力发电厂测量装置配置选型及厂用电管理系统
  • 【RabbitMQ】RabbitMQ整合SpringBoot案例
  • 如何在window下cmd窗口执行linux指令?
  • c++基础系列:字符串、向量和数组
  • docker 05(dockerfile)
  • PostMan 测试项目是否支持跨域
  • jsp 协同过滤 图书管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
  • 商城-学习整理-高级-商城业务-商品上架es(十)
  • 【水文学法总结】河道内生态流量计算方法(含MATLAB实现代码)
  • 特斯拉Model 3的七年狂飙