- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
补充:C语言中常用的串运算 调用标准库函数 #includestring.h 串比较,strcmp(char s1,char s2) 串复制,strcpy(char to,char from) 串连接,strcat(char to,char from) 求串长,strlen(char s) …… 4.1.1 串的基本概念 串(String):零个或多个字符组成的有限序列。 4.1.1 串的基本概念 a=‘BEI’, b=‘JING’ c=‘BEIJING’ d=‘BEI JING’ a和b是c和d的子串 a在c和d中的位置是1。 b在c中的位置是4,在d中的位置为5。 ‘ ’是空格串Φ 4.1.2 串的抽象数据类型 ADT String{ 数据对象:D = { ai|ai∈CharacterSet, i=1,2,…,n, n ≥0 } 数据关系:R = {ai-1, ai| ai-1, ai∈D, i=2,3,…,n } 基本操作: ⑴ StrLength (s):求串s的长度。 ⑵ StrAssign (s1, s2):赋值,将s2的值赋值给串s1。 ⑶ StrConcat (s1, s2, s):连接,将串s2放在串s1的后面连接成一个新串s。 ⑷ SubStr (s, i, len):求子串,返回从串s的第i个字符开始取长为 len 的子串。 4.1.2 串的抽象数据类型 ⑸ StrCmp (s1, s2):串比较,若s1=s2,返回0;若s1s2, 返回-1;若s1s2, 返回1。 ⑹ StrIndex (s, t):定位,返回子串t在主串s中首次出现的位置。若t不是s的子串,则返回0。 ⑺ StrInsert (s, i, t):插入,将串t插入到串s中的第i个位置。 ⑻ StrDelete (s, i, len):删除,在串s中删除从第i个字符开始的连续len个字符。 ⑼ StrRep (s, t, r):替换,在串s中用串r替换所有与串t相等的子串。 }ADT String 4.1.2 串的抽象数据类型 求子串操作SubStr(s, i, len)示例 4.1.3 串与线性表的比较 逻辑结构 串的逻辑结构和线性表极为相似,区别仅在于串的数据对象约束为字符集。 基本操作 在线性表的基本操作中,大多以“单个元素”作为操作对象; 在串的基本操作中,通常以“串的整体”作为操作对象。 4.1.4 串的存储结构 串是一种特殊的线性表,其存储表示和线性表类似,但又不完全相同。串的存储方式取决于将要对串所进行的操作。串在计算机中有3种表示方式: 定长顺序存储表示:将串定义成字符数组,利用串名可以直接访问串值。用这种表示方式,串的存储空间在编译时确定,其大小不能改变。 堆分配存储方式:仍然用一组地址连续的存储单元来依次存储串中的字符序列,但串的存储空间是在程序运行时根据串的实际长度动态分配的。 块链存储方式:是一种链式存储结构表示。 4.1.4 串的存储结构 串的定长顺序存储表示 这种存储结构又称为串的顺序存储结构。是用一组连续的存储单元来存放串中的字符序列。所谓定长顺序存储结构,是直接使用定长的字符数组来定义,数组的上界预先确定。 特点: 串的实际长度可在这个予定义长度的范围内随意设定,超过予定义长度的串值则被舍去,称之为“截断” 。 按这种串的表示方法实现的串的运算时,其基本操作为 “字符序列的复制”。 定长顺序存储结构定义为: #define MAX_STRLEN 256 typedef struct { char str[MAX_STRLEN] ; int length; } StringType ; 4.1.4 串的存储结构 4.1.4 串的存储结构 串的联接算法中需分三种情况处理: Status Concat(SString S1, SString S2, SString T) { // 用T返回由S1和S2联接而成的新串。若未截断, 则返回TRUE,否则FALSE。 if (S1[0]+S2[0] = MAXSTRLEN) {// 未截断 T[1..S1[0]] = S1[1..S1[0]]; T[S1[0]+1..S1[0]+S2[0]] = S2[1..S2[0]]; T[0] = S1[0]+S2[0]; uncut = TRUE; } else if (S1[0] MAXSTRLEN) { // s2截断,s1未截断 T[1..S1[0]
您可能关注的文档
最近下载
- 剑桥少儿英语一级下册Unit3.ppt VIP
- 矿产资源“三率”指标要求 第5部分:金、银、铌、钽、锂、锆、锶、稀土、锗 0462.5-2023.pdf
- 期末考试试题集-自动控制原理含完整答案.docx VIP
- 生成式人工智能原理及其影响和应用(南开大学)学习通网课章节测试答案.docx
- Q/GDW 13238.3—2018 10kV电力电缆采购标准(第3部分:10kV三芯电力电缆-专用技术规范).pdf VIP
- 政治经济学知到智慧树期末考试答案题库2024年秋首都经济贸易大学.docx VIP
- NB∕T 20509-2018 压水堆核电厂机组负荷扰动试验.pdf
- 2025年去哪儿快消行业CNY春节合作方案.pptx VIP
- GB50169-2016 电气装置安装工程接地装置施工及验收规范附条文.docx VIP
- 单机试车方案汇.doc VIP
文档评论(0)