C语言 数据结构与算法之字符串详解
程序员文章站
2022-06-17 17:38:52
目录串的定义串的比较串的抽象数据类型串的初始化相关定义初始化定长类初始化串的堆式顺序存储结构(heap)初始化堆字符串赋值操作比较两个堆字符串的大小串的定义零个或多个字符组成的有限序列串的比较串的比较...
串的定义
零个或多个字符组成的有限序列
串的比较
串的比较实际上是在比较串中字符的编码
存在某个k < min(n,m),使得ai = bi (i = 1,2,3,4..k)
如果 ak < bk --> 那么srt1 < srt2 (反之也成立)
除去相等的字符,在第一个不相等的字符位置以ascii码进行比较
串的抽象数据类型
串的顺序存储结构示意图
串的顺序存储结构是用一组地址连续的存储单元来存储串中的字符序列
typedef struct sqstring{ char* ch; //若串为空,则按串长分配存储区 //否则ch = null int length;//串长 }sqstring;
串的初始化
相关定义初始化
/** 状态码 **/ #define true 1 #define false 0 #define eq 0 #define gt 1 //大于 #define lt -1 //小于
定长类初始化
#define max_size 1024 typedef struct{ char ch[max_size + 1]; //定长方式实现了字符串的顺序结构--缺点是浪费空间 int length; }sstring;
串的堆式顺序存储结构(heap)
/** 串的堆式顺序存储结构(heap)**/ typedef struct{ char * ch; //如果是非空串,那么就按照指定长度分配内存,否则ch就指向null int length; //串当前长度 }hstring;
初始化堆字符串
赋值操作
/** 为串str赋值,值为字符串常量chars **/ void strassign_heapstring(hstring * str,char * chars){ int len = strlen(chars); if(!len) return error; initstring_heapstring(str); //动态为字符串分配空间 str->ch = (char*)malloc(len * sizeof(char)); if(!str->ch){ exit(overflow); //内存溢出,分配失败 } //逐个将字符串输入所分配的空间中 for(int i = 0;i < len ; i++) { str->ch[i] = chars[i]; } str->length = len; //将长度赋值 return ok; }
比较两个堆字符串的大小
str1 == str2 返回0 ; str1 < str2 返回-1 ; str1 > str2 返回1
status strcmp_heapstring(hstring * str1,hstring * str2){ for(int i = 0;i < str->length && i < str2->length; i ++){ //遇到不同的字符就直接比较ascii if(str->ch[i] != str[2]->ch[i]){ //大于则返回整数,小于则返回负数 return str->ch[i] - str[2]->ch[i]; } } //字符都相等但是长度不等,就比较长度 return str1->length - str2->length; }
到此这篇关于c语言 数据结构与算法之字符串详解的文章就介绍到这了,更多相关c语言 字符串内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!