C语言第28天,字符串使用与剖析(二),strstr,strtok,strerror

本文详细介绍了C语言中处理字符串的三个关键函数:strstr用于查找子字符串,strtok将字符串分解为多个部分,而strerror则用于获取错误信息。通过实例讲解了它们的使用方法和注意事项。

strstr - 查找子字符串

#define _CRT_SECURE_NO_WARNINGS

#include <stdio.h>
#include <string.h>

//strstr - 查找子字符串

char* my_strstr(const char* p1, const char* p2) {
	char* s1 = NULL;
	char* s2 = NULL;
	char* cur = (char*)p1;
	if (*p2 == '\0') {
		return (char*)p1;
	}
	while (*cur) {
		s1 = cur;
		s2 = (char*)p2;
		while ((*s1 == *s2) && *s2 && *s1) {
			s1++;
			s2++;
		}
		if (*s2 == '\0') {
			return cur;//找到子串
		}
		cur++;
	}
	return NULL;//找不到子串
}

int main() {
	char* p = "abcdef";
	char* p2 = "bcd";
	//查找p1中是否有p2
	char* ret = strstr(p, p2);
	if (ret == NULL) {
		printf("子串不存在\n");
	}
	else {
		printf("%s\n", ret);//bcdef
	}
	char* ret2 = my_strstr(p, p2);
	if (ret2 == NULL) {
		printf("子串不存在\n");
	}
	else {
		printf("%s\n", ret2);//bcdef
	}
	return 0;
}
bcdef
bcdef

strtok - 分解字符串为一组字符串

#define _CRT_SECURE_NO_WARNINGS

#include <stdio.h>
#include <string.h>

//strtok - 分解字符串为一组字符串
//第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记
//strtok函数找到str中的下一个标记,并将其用\0结尾,返回一个指向这个标记的指针。
//(strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改)
//strtok函数的第一个参数不为NULL,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置
//如果字符串中不存在更多的标记,则返回NULL指针

int main() {
	char arr[] = "abc,def,ghi,jkl";
	char* ret = strtok(arr, ",");
	printf("%s\n", ret);//abc
	ret = strtok(NULL, ",");
	printf("%s\n", ret);//def
	ret = strtok(NULL, ",");
	printf("%s\n", ret);//ghi
	ret = strtok(NULL, ",");
	printf("%s\n", ret);//jkl
	ret = strtok(NULL, ",");
	printf("%s\n", ret);//(null)

	printf("---------------------\n");

	char arr2[] = "110@qq.com";
	char* p1 = "@.";
	char* ret2 = NULL;
	for (ret2 = strtok(arr2, p1); ret2 != NULL; ret2 = strtok(NULL, p1)) {
		printf("%s\n", ret2);//110  qq  com
	}
	return 0;
}
abc
def
ghi
jkl
(null)
---------------------
110
qq
com

strerror - 返回错误信息

#define _CRT_SECURE_NO_WARNINGS

#include <stdio.h>
#include <string.h>

//strerror - 返回错误信息

int main() {
	//错误码 错误信息
	//0  -  No error
	//1  -  Operation not permitted
	//2  -  No such file or directory
	char* str1 = strerror(0);
	printf("%s\n", str1);
	char* str2 = strerror(1);
	printf("%s\n", str2);
	char* str3 = strerror(2);
	printf("%s\n", str3);
	return 0;
}
No error
Operation not permitted
No such file or directory
基于数据驱动的 Koopman 算子的递归神经网络模型线性化,用于纳米定位系统的预测控制研究(Matlab代码实现)内容概要:本文围绕“基于数据驱动的Koopman算子的递归神经网络模型线性化”展开,旨在研究纳米定位系统的预测控制问题,并提供完整的Matlab代码实现。文章结合数据驱动方法Koopman算子理论,利用递归神经网络(RNN)对非线性系统进行建模线性化处理,从而提升纳米级定位系统的精度动态响应性能。该方法通过提取系统隐含动态特征,构建近似线性模型,便于后续模型预测控制(MPC)的设计优化,适用于高精度自动化控制场景。文中还展示了相关实验验证仿真结果,证明了该方法的有效性和先进性。; 适合人群:具备一定控制理论基础和Matlab编程能力,从事精密控制、智能制造、自动化或相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于纳米级精密定位系统(如原子力显微镜、半导体制造设备)中的高性能控制设计;②为非线性系统建模线性化提供一种结合深度学习现代控制理论的新思路;③帮助读者掌握Koopman算子、RNN建模模型预测控制的综合应用。; 阅读建议:建议读者结合提供的Matlab代码逐段理解算法实现流程,重点关注数据预处理、RNN结构设计、Koopman观测矩阵构建及MPC控制器集成等关键环节,并可通过更换实际系统数据进行迁移验证,深化对方法泛化能力的理解。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值