串---顺序串实现
顺序串详解
本文档将详细介绍顺序串的基本概念、实现原理及其在 C 语言中的具体应用。通过本指南,读者将了解如何使用顺序串进行各种字符串操作。
1. 什么是顺序串?
顺序串是一种用于存储字符串的数据结构,它使用一组连续的内存空间来保存字符串中的字符序列。顺序串通常由两部分组成:
- 一个字符数组
data[]
,用于存储实际的字符数据。 - 一个整数
length
,用于记录字符串的实际长度。
在本程序中,我们定义了一个名为 SequentialString
的结构体来表示顺序串。
typedef struct SequentialString {char data[MaxSize]; // 实际字符int length; // 字符串长度
} SequentialString;
其中 MaxSize
是一个预定义的最大字符串长度常量。
2. 基本操作
2.1 生成串 (StrAssign
)
此函数用于将一个 C 语言字符串转换为顺序串。
void StrAssign(SequentialString &s, const char str[]);
参数:
s
: 目标顺序串。str
: 源 C 语言字符串。
功能:
- 复制
str
中的所有字符到s.data[]
,并设置s.length
为实际复制的字符数量。
2.2 复制串 (StrCopy
)
此函数用于将一个顺序串复制到另一个顺序串。
void StrCopy(SequentialString &s, SequentialString t);
参数:
s
: 目标顺序串。t
: 源顺序串。
功能:
- 复制
t
的所有字符到s.data[]
,并设置s.length
与t.length
相同。
2.3 判断是否为空串 (StrEmpty
)
此函数用于检查一个顺序串是否为空。
bool StrEmpty(SequentialString &s);
参数:
s
: 要检查的顺序串。
返回值:
- 如果
s.length
为 0,则返回true
;否则返回false
。
2.4 判断两个串是否相等 (StrEqual
)
此函数用于检查两个顺序串是否相等。
bool StrEqual(SequentialString s, SequentialString t);
参数:
s
: 第一个顺序串。t
: 第二个顺序串。
返回值:
- 如果两个串的长度相同且所有字符都相等,则返回
true
;否则返回false
。
2.5 获取串的长度 (StrLength
)
此函数用于获取一个顺序串的长度。
int StrLength(SequentialString s);
参数:
s
: 要获取长度的顺序串。
返回值:
- 返回
s.length
。
2.6 串的连接 (Concat
)
此函数用于将两个顺序串连接成一个新的顺序串。
SequentialString Concat(SequentialString s, SequentialString t);
参数:
s
: 第一个顺序串。t
: 第二个顺序串。
返回值:
- 返回一个新的顺序串,该串包含
s
和t
的所有字符。
2.7 获取子串 (SubStr
)
此函数用于从一个顺序串中获取指定位置的子串。
SequentialString SubStr(SequentialString s, int i, int j);
参数:
s
: 原始顺序串。i
: 子串的起始位置(1-indexed)。j
: 子串的长度。
返回值:
- 返回一个新的顺序串,该串包含
s
从位置i
开始的长度为j
的子串。
2.8 子串插入 (InsertStr
)
此函数用于在一个顺序串的指定位置插入另一个顺序串。
SequentialString InsertStr(SequentialString s1, SequentialString s2, int i);
参数:
s1
: 原始顺序串。s2
: 要插入的顺序串。i
: 插入位置(1-indexed)。
返回值:
- 返回一个新的顺序串,该串包含
s1
和在位置i
插入的s2
。
2.9 子串删除 (DelStr
)
此函数用于从一个顺序串中删除指定位置的子串。
SequentialString DelStr(SequentialString s, int i, int j);
参数:
s
: 原始顺序串。i
: 子串的起始位置(1-indexed)。j
: 子串的长度。
返回值:
- 返回一个新的顺序串,该串包含
s
除位置i
开始的长度为j
的子串外的所有字符。
2.10 子串替换 (RepStr
)
此函数用于在一个顺序串的指定位置替换一个子串。
SequentialString RepStr(SequentialString s, int i, int j, SequentialString t);
参数:
s
: 原始顺序串。i
: 要替换子串的起始位置(1-indexed)。j
: 要替换子串的长度。t
: 新的子串。
返回值:
- 返回一个新的顺序串,该串包含
s
除位置i
开始的长度为j
的子串被t
替换外的所有字符。
2.11 输出串 (displayStr
)
此函数用于显示一个顺序串的内容。
void displayStr(SequentialString s);
参数:
s
: 要显示的顺序串。
2.12 串的比较 (StrCompare
)
此函数用于比较两个顺序串。
int StrCompare(SequentialString s, SequentialString t);
参数:
s
: 第一个顺序串。t
: 第二个顺序串。
返回值:
- 如果
s
和t
相等,返回 0; - 如果
s
小于t
,返回负数; - 如果
s
大于t
,返回正数。
3. 示例程序
下面是一个示例程序,演示了如何使用上述定义的功能。
#include <stdio.h>
#include <stdlib.h>#define MaxSize 100// 定义顺序串的结构体
typedef struct SequentialString {char data[MaxSize]; // 实际字符int length; // 字符串长度
} SequentialString;// 生成串
void StrAssign(SequentialString &s, const char str[]) {int i;for (i = 0; str[i] != '\0'; i++) { // 复制字符直到遇到空字符s.data[i] = str[i];}s.length = i; // 设置字符串长度
}// 复制串
void StrCopy(SequentialString &s, SequentialString t) {int i;for (i = 0; i < t.length; i++) { // 复制字符s.data[i] = t.data[i];}s.length = t.length; // 设置字符串长度
}// 判断是否为空串
bool StrEmpty(SequentialString &s) {return s.length == 0;
}// 判断两个串是否相等
bool StrEqual(SequentialString s, SequentialString t) {bool same = true;int i;if (s.length != t.length) { // 检查长度是否相同same = false;} else {for (i = 0; i < s.length; i++) { // 逐个字符比较if (s.data[i] != t.data[i]) {same = false;break;}}}return same;
}// 获取串的长度
int StrLength(SequentialString s) {return s.length;
}// 串的连接
SequentialString Concat(SequentialString s, SequentialString t) {SequentialString str;int i;str.length = s.length + t.length; // 计算新字符串长度for (i = 0; i < s.length; i++) { // 复制第一个串str.data[i] = s.data[i];}for (i = 0; i < t.length; i++) { // 连接第二个串str.data[s.length + i] = t.data[i];}return str;
}// 获取子串
SequentialString SubStr(SequentialString s, int i, int j) {int k;SequentialString str;str.length = 0;if (i <= 0 || j > s.length || j < 0 || i + j - 1 > s.length) { // 检查边界条件return str;}for (k = i - 1; k < i + j - 1; k++) { // 复制子串str.data[k - i + 1] = s.data[k];}str.length = j; // 设置子串长度return str;
}// 子串插入
SequentialString InsertStr(SequentialString s1, SequentialString s2, int i) {int j;SequentialString str;str.length = 0;if (i <= 0 || i > s1.length + 1) { // 检查边界条件return str;}for (j = 0; j < i - 1; j++) { // 复制前缀str.data[j] = s1.data[j];}for (j = 0; j < s2.length; j++) { // 插入子串str.data[j + i - 1] = s2.data[j];}for (j = i - 1; j < s1.length; j++) { // 连接剩余部分str.data[j + s2.length] = s1.data[j];}str.length = s1.length + s2.length; // 更新长度return str;
}// 子串删除
SequentialString DelStr(SequentialString s, int i, int j) {int k;SequentialString str;str.length = 0;if (i <= 0 || j > s.length || i + j > s.length + 1) { // 检查边界条件return str;}for (k = 0; k < i - 1; k++) { // 复制前缀str.data[k] = s.data[k];}for (k = i + j - 1; k < s.length; k++) { // 复制后缀str.data[k - j] = s.data[k];}str.length = s.length - j; // 更新长度return str;
}// 子串替换
SequentialString RepStr(SequentialString s, int i, int j, SequentialString t) {int k;SequentialString str;str.length = 0;if (i <= 0 || j > s.length || i + j - 1 > s.length + 1) { // 检查边界条件return str;}for (k = 0; k < i - 1; k++) { // 复制前缀str.data[k] = s.data[k];}for (k = 0; k < t.length; k++) { // 替换子串str.data[i + k - 1] = t.data[k];}for (k = i + j - 1; k < s.length; k++) { // 连接剩余部分str.data[t.length + k - j] = s.data[k];}str.length = s.length - j + t.length; // 更新长度return str;
}// 输出串
void displayStr(SequentialString s) {int i;for (i = 0; i < s.length; i++) { // 输出每个字符printf("%c", s.data[i]);}printf("\n");
}// 串的比较
int StrCompare(SequentialString s, SequentialString t) {int i;int commonLength;if (s.length < t.length) {commonLength = s.length;} else {commonLength = t.length;}for (i = 0; i < commonLength; i++) { // 逐个字符比较if (s.data[i] > t.data[i]) {return 1;} else if (s.data[i] < t.data[i]) {return -1;}}if (s.length == t.length) {return 0;} else if (s.length > t.length) {return 1;} else {return -1;}
}int main() {SequentialString s, t;char input[MaxSize];// 用户输入第一个串printf("请输入第一个字符串: ");scanf("%s", input);StrAssign(s, input);// 用户输入第二个串printf("请输入第二个字符串: ");scanf("%s", input);StrAssign(t, input);// 显示两个串printf("第一个字符串: ");displayStr(s);printf("第二个字符串: ");displayStr(t);// 检查是否为空串if (StrEmpty(s)) {printf("第一个串为空串。\n");} else {printf("第一个串不为空串。\n");}if (StrEmpty(t)) {printf("第二个串为空串。\n");} else {printf("第二个串不为空串。\n");}// 比较两个串int result = StrCompare(s, t);if (result == 0) {printf("两个串相等。\n");} else if (result < 0) {printf("第一个串小于第二个串。\n");} else {printf("第一个串大于第二个串。\n");}// 计算两个串的长度printf("第一个串的长度为: %d\n", StrLength(s));printf("第二个串的长度为: %d\n", StrLength(t));// 连接两个串SequentialString concatenated = Concat(s, t);printf("连接后的字符串: ");displayStr(concatenated);// 获取子串int start, length;printf("请输入子串起始位置 (1-%d): ", s.length);scanf("%d", &start);printf("请输入子串长度: ");scanf("%d", &length);SequentialString substring = SubStr(s, start, length);printf("子串为: ");displayStr(substring);// 插入子串printf("请输入插入位置 (1-%d): ", StrLength(s) + 1);scanf("%d", &start);SequentialString inserted = InsertStr(s, t, start);printf("插入后的字符串: ");displayStr(inserted);// 删除子串printf("请输入删除起始位置 (1-%d): ", s.length);scanf("%d", &start);printf("请输入删除长度: ");scanf("%d", &length);SequentialString deleted = DelStr(s, start, length);printf("删除后的字符串: ");displayStr(deleted);// 替换子串printf("请输入替换起始位置 (1-%d): ", s.length);scanf("%d", &start);printf("请输入替换长度: ");scanf("%d", &length);SequentialString replaced = RepStr(s, start, length, t);printf("替换后的字符串: ");displayStr(replaced);return 0;
}
4. 使用说明
- 编译并运行上述示例程序。
- 根据提示输入两个字符串。
- 观察并理解各个操作的结果。
5. 总结
通过本文档,您可以了解到顺序串的基本概念和常用操作。使用这些操作,您可以轻松地处理字符串数据,进行各种字符串相关的任务。希望这份指南能够帮助您更好地理解和使用顺序串。
相关文章:
串---顺序串实现
顺序串详解 本文档将详细介绍顺序串的基本概念、实现原理及其在 C 语言中的具体应用。通过本指南,读者将了解如何使用顺序串进行各种字符串操作。 1. 什么是顺序串? 顺序串是一种用于存储字符串的数据结构,它使用一组连续的内存空间来保存…...
吴恩达机器学习WEEK2
COURSE1 WEEK2 多维特征 在线性回归中,往往特征不止一个,而是具有多维特征 例如,在预测房价的例子中,我们知道更多的信息: x 1 x_1 x1:房屋的面积 x 2 x_2 x2:卧室的数目 x 3 x_3 x3&a…...
yield and generator in python
首先,假设大家都对于pytyhon的List comprehension的使用有了一定经验(它可以用于list,set,和dict哦) 不熟悉的参考介绍: Comprehending Python’s Comprehensions – dbader.org generator generator是哦…...
spring原理(自学第六天)
Aware 接口及 InitializingBean 接口 今天将会学到Aware 接口及 InitializingBean 接口 我们可以先了解他们的作用: 1. Aware 接口用于注入一些与容器相关信息, 例如 a. BeanNameAware 注入 bean 的名字 b. BeanFactoryAware 注入…...
案例分享—国外优秀ui设计作品赏析
国外UI设计创意迭出,融合多元文化元素,以极简风搭配动态交互,打造沉浸式体验,色彩运用大胆前卫,引领界面设计新风尚 同时注重用户体验的深度挖掘,通过个性化定制与智能算法结合,让界面不仅美观且…...
【C++】简约与清晰的编程艺术
C编程的艺术:简约与清晰的实践之道 一、基础之美:基本类型与数据结构的力量二、函数与库类的艺术三、简约与清晰的实践之道 在C这一既古老又充满活力的编程语言世界里,程序员们常常面临着一个重要的选择:是追求代码的极致抽象与封…...
java之WIFI信号模块
开发步骤分为以下几点: 1.在 AndroidManifest 中声明相关权限(网络和文件读写权限) 声明权限: <uses-permission android:name"android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name"android.…...
Mybatis面试
Mybatis 面试 1、Mybatis 的执行流程是什么? 1、读取MyBatis配置文件:mybatis-config.xml 加载运行环境 和 映射文件 2、构造会话工厂 SqlSessionFactory (全局只有一个) 3、会话工厂创建SqlSession对象(项目与数据…...
Centos 8系统xfs文件系统类型进行扩容缩容 (LVM)
Centos 8系统xfs文件系统类型进行扩容缩容 (LVM),xfs分区类型是不支持正常缩容,只能强制缩容 1.磁盘情况:2.缩容home分区1.备份home数据:2.查找使用 /home 的进程:3.终止这些进程:4.卸载 /home …...
C语言基础知识之函数指针和指针函数
函数指针和指针函数 函数指针和指针函数指向函数的指针返回指针值的函数指针函数和函数指针的区别 问题1_1代码1_1结果1_1 函数指针和指针函数 指向函数的指针 用函数指针变量调用函数 可以用指针变量指向整型变量、字符串、数组,也可以指向一个函数。一个…...
【Unity】web gl inputFied 中文输入,同时支持TextMeshInputFied,支持全屏
同时支持TextMeshInputFied,支持全屏。 使用github包【WebGLInput】:https://github.com/kou-yeung/WebGLInput 需要资源的在这里也可以下载 https://download.csdn.net/download/weixin_46472622/89600795 用于unity web gl 中文输入,只需…...
vue3+vite全局引入less变量和函数
需要在vite配置 plugins: [css: {preprocessorOptions: {less: {additionalData: import "./src/styles/variables.module.less"; import "./src/views/Visualization/component/ViewportCom/px2viewport.less";,javascriptEnabled: true}}}, ]多个文件按…...
H81002S 1.7mm网络变压器:BMS汽车蓝牙接收器中的超薄共模电感科技
华强盛导读:在当今这个日新月异的汽车科技领域,每一处细节都蕴含着创新与突破。作为电动汽车心脏的电池管理系统(BMS),其高效稳定的运行不仅关乎续航与安全,更是智能化驾驶体验的基石。而在这背后ÿ…...
C语言.回调函数
回调函数 回调函数也是一个函数。与一般函数直接调用区别在于,使用回调函数的过程,是一个函数将另一个函数作为参数调用。而被用来调用的那个函数,就是回调函数。 回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地…...
《从零开始:使用Python构建简单Web爬虫》
前言 随着互联网信息的爆炸性增长,如何高效地获取和处理这些数据变得越来越重要。Web爬虫作为一种自动化工具,可以帮助我们快速抓取所需的网页内容。本文将介绍如何使用Python编写一个简单的Web爬虫,并通过实例演示其基本用法。 准备工作 …...
最新个人免签约支付系统源码|PHP源码 | 码支付系统 | ThinkPHP6框架 | 开源
源码介绍: 这个最新的个人专用免签约支付系统源码!是PHP源码写的哦,而且是用ThinkPHP6框架开发的,完全开源的码支付系统。 这个系统适合个人用户使用,作为收款的免签约解决方案。它还加入了监控端,可以拒…...
The Llama 3 Herd of Models 第4部分后训练的全文
Llama 3前三部分包括介绍、总体概述和预训练https://blog.csdn.net/qq_51570094/article/details/140682445?spm=1001.2014.3001.5501 4 Post-Training 后训练 我们通过应用几轮后训练6或将模型与人类反馈对齐来生成对齐的Llama 3模型(Ouyang等人,2022;Rafailov等人,2024)在…...
MongoDB性能调优
文章目录 MongoDB性能调优MongoDB性能不佳原因影响MongoDB性能的因素MongoDB性能监控工具mongostatmongotopProfiler模块db.currentOp() MongoDB性能调优 MongoDB性能不佳原因 慢查询阻塞等待硬件资源不足 1,2通常是因为模型/索引设计不佳导致的 排查思路:按1-2…...
【Qt开发】调试log日志QDebug重定向输出到textEdit等控件(qInstallMessageHandler回调函数)
【Qt开发】调试log日志QDebug重定向输出到textEdit等控件(qInstallMessageHandler回调函数) 文章目录 Log输出方式qInstallMessageHandler回调函数线程安全textEdit控件附录:C语言到C的入门知识点(主要适用于C语言精通到Qt的C开发…...
【JavaEE精炼宝库】 网络编程套接字——UDP业务逻辑 | TCP流套接字编程及业务逻辑实现
文章目录 一、UDP业务逻辑实现二、TCP流套接字编程2.1 API 介绍:2.1.1 ServerSocket:2.1.2 Socket: 2.2 Java流套接字通信模型:2.3 代码示例:2.3.1 TCP Echo Server:2.3.2 TCP Echo Client:2.3.…...
前端过渡动画
前端过渡动画 vue3 1、组件进入视口时向上移动且渐显 1、创建js文件addViewportEffect.js function slideDownEffect(element) {console.log("执行");element.style.transform translateY(0);element.style.opacity 1; }/*** 添加视口效果到指定的类名元素上。…...
actual combat 38 ——vue
vue-cli脚手架 创建命令:vue create 项目名称 eslint 如何关闭? vue.config.js文件中加 module.exports {lintOnSave: false }文件全代码: const { defineConfig } require(vue/cli-service) module.exports defineConfig({transpile…...
测试面试宝典(四十七)— 功能测试用例一般包含哪些内容
首先,明确测试用例的编号和名称,以便于识别和管理。 其次,详细描述测试的目标和背景,让其他人能够清楚了解该测试用例的目的和适用场景。 接着是测试的步骤,需要清晰、准确地列出每一个操作步骤,包括输入…...
rust_mac环境安装
在 macOS 上安装 Rust 很简单。你可以使用 Rust 提供的安装工具 rustup。下面是安装步骤: 打开终端。 运行以下命令以安装 rustup 和 Rust: curl --proto https --tlsv1.2 -sSf https://sh.rustup.rs | sh按照提示进行操作: 这个命令将下载并…...
【前端面试】七、算法-递归
常考算法 排序算法:快速排序、归并排序、堆排序等。 查找算法:二分查找、哈希表查找等。 动态规划:解决最优化问题,如斐波那契数列、最长公共子序列等。 图论算法:最短路径(Dijkstra、Floyd-Warshall&am…...
CmsEasy逻辑漏洞--零元购
CmsEasy逻辑漏洞--零元购 选择购买MackBook 购买成功后会员中心发现多出8100快钱 然后就可以正常购买了...
Linux 内核源码分析---I/O 体系结构与访问设备
I/O 体系结构 与外设的通信通常称之为输入输出,一般都缩写为I/O。 在实现外设的I/O时,内核必须处理3个可能出现的问题: (1)必须根据具体的设备类型和模型,使用各种方法对硬件寻址; (…...
在cPanelWHM中如何重置 MySQL 用户帐户密码
更改MySQL用户账户密码非常简单。服务器管理员可以在WHM中编辑任何MySQL用户的帐户。cPanel用户可以编辑其帐户管理的数据库的密码。 在WHM中更改MySQL用户帐户密码 打开WHM,在侧边菜单中的SQL服务下选择“Change MySQLUser Password”。Hostease的服务器产品提供稳…...
软件测试基础1--功能测试
1、什么是软件测试? 软件是控制计算机硬件运行的工具。 软件测试:使用技术手段验证软件是否满足使用需求,为了发现软件功能和需求不相符合的地方,或者寻找实际输出和预期输出之间的差异。 软件测试的目的:减少软件缺陷…...
《计算机网络》(第8版)第9章 无线网络和移动网络 复习笔记
第 9 章 无线网络和移动网络 一、无线局域网 WLAN 1 无线局域网的组成 无线局域网提供移动接入的功能,可分为两大类:有固定基础设施的和无固定基础设 施的。 (1)IEEE 802.11 IEEE 802.11 是无线以太网的标准,是有固定…...
做头像网站有哪些/百度网址大全官方下载
题目 有 N 种物品和一个容量是 V 的背包,每种物品都有无限件可用。 第 ii 种物品的体积是 vi,价值是 wi。 求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值最大。 输出最大价值。 输入格式 第一行两个整…...
网站建设项目管理论文/广州网站营销推广
前几日,有网友提了一个问题:用blueprint注册了 一个servlet服务,并将另一个osgi服务注入这个 servlet服务bean里,以便在处理用户的http请求 时调用。但是部署运行后,发现servlet那里注入 的osgi服务一直为null。 表面上࿰…...
asp.net网站管理系统/自助建站网站模板
使用poi需要用到的jar包 本文的导出基于execl的模板导出,在大部分表头固定而格式花样比较复杂的建议使用本文介绍的方法(表头固定,只需要填充值) 1、在webroot目录下新建report文件夹来存放模板execl文件 2、jsp前台请求对应的act…...
利用jsp做网站/网页制作基础教程
1. 效果 先看看效果图 这是传输文件完成的界面 客户端 服务端 2. 知识准备 其实文件传输和聊天室十分相似,只不过一个传输的是文字,一个传输的是文件,而这方面的知识,我已经在前面的博客写过了,不了解的同学可以去…...
企业网站建设方案流程/百度客户端官网
1、float整数计算误差 案例:会员积分字段采用float类型,导致计算会员积分时,7位整数的数据计算结果出现误差。 原因:超出float精度范围,无法精确计算。 float和double的精度是由尾数的位数来决定的。浮点数在内存中是按…...
什么网站可以免费做护师题/今日国际军事新闻最新消息
1.html 1 <!DOCTYPE html> 有无demo 种类之间的区别html文件包含2个大部分:head -meta 页面的编码跳转页面缓存关键字x-UA-compatibletitlelink - stylesheet -iconstylescript body中的标签 行内 aimglabelspanselect input块级标签 divf…...