【C语言】关于字符串函数的使用及模拟实现(1)

一、字符串追加

1.1 库函数srecat的使用

1.2 库函数strncat的使用

1.3 模拟实现库函数 strcat 及 strncat

由上可知,字符串追加的原理是找到所添加字符串的 \0 位置,再对其进行添加。

代码1、

代码2、


二、字符串查找

2.1 库函数strstr的使用

使用strstr函数可以快速的定位到所查找字符串的地址。

2.2 模拟实现库函数 strstr

复制代码
//模拟实现字符串查找
#include<stdio.h>
char* my_strstr(const char* a,const char* b){
	const char* a1 = a;  
	const char* b1 = b;  
	const char* p = a;    // 记录从字符串a开始查找的位置
	if(*b == '\0'){
		return (char*)a;
	}
	while(*p){
		a1 = p;
		b1 = b;  // 重置指向字符串b的指针
		while(*a1 && *b1 && (*a1 == *b1)){
			a1++;
			b1++;
		}
		if(*b1 == '\0'){ //表示已查完,返回开始查找的位置
			return (char*)p;
		}
	p++;
	}
	return NULL; //未查找到
}

int main(){
	char a[20] = "hongshaorou";
	char b[] = "shao";
	char * ret = my_strstr(a,b);
	if(ret == NULL){
		printf("没找到");
	}else{
		printf("找到了:%s\n",ret);	
	}
	return 0;
}

三、求字符串长度

3.1 库函数strlen的使用

记录 ' \0 ' 之前的字符数。

3.2 模拟实现库函数strlen

注意:在库函数中strlen的返回类型为suze_t(无符号整型),我们这里的返回类型为int型。

代码1

复制代码
#include<stdio.h>
int my_strlen(const char* a){
	int count = 0;
	while(*a){
		a++;
		count++;
	}
	return count;
}

int main(){
	char a[] = "hello";
	int len = my_strlen(a);
	printf("%d\n",len);
	
	return 0;
}

代码2

复制代码
#include<stdio.h>
int my_strlen(const char* a){
	const char* p = a;
	while(*a){
		a++;
	}
	return (int)(a-p);
}
int main(){
	char a[] = "hello";
	int len = my_strlen(a);
	printf("%d\n",len);
	return 0;
}
相关推荐
似水এ᭄往昔40 分钟前
【C语言】编译和链接
c语言·开发语言
W说编程1 小时前
《UNIX网络编程卷1:套接字联网API》第4章 基本TCP套接字编程
c语言·网络·网络协议·tcp/ip·架构·unix·tcp
南玖yy1 小时前
数据结构C语言练习(设计循环队列)
java·c语言·数据结构
_GR1 小时前
2023年蓝桥杯第十四届C&C++大学B组真题及代码
c语言·c++·蓝桥杯
努力努力再努力wz1 小时前
【c++深入系列】:类和对象详解(下)
java·运维·c语言·开发语言·c++
明月醉窗台2 小时前
Qt 入门 3 之对话框 QDialog(1)
c语言·开发语言·c++·qt
凯强同学5 小时前
第十五届蓝桥杯大赛软件赛省赛Python 大学 C 组:6.挖矿
c语言·python·算法·职场和发展·蓝桥杯
march_birds5 小时前
Zephyr与Linux核心区别及适用领域分析
c语言·开发语言·单片机·系统架构
搜搜秀7 小时前
linux (CentOS 10)使用传统程序语言(C)进行编译---主,子程序连接:子程序的编译
linux·c语言·centos
Dovis(誓平步青云)7 小时前
【数据结构】排序算法(下篇·开端)·深剖数据难点
c语言·数据结构·学习·算法·排序算法·推荐算法