保姆级讲解字符串函数(上篇)

news2025/6/18 15:47:52

目录

字符分类函数

导图

函数介绍 

1.getchar

2. isupper 和 islower

字符转换函数:(toupper , tolower) 与 putchar

字符串函数

导图

 string函数的使用和模拟实现

string的使用

 求字符串长度

字符串的比较 

string函数的模拟实现

strcpy 与 strncpy

 strcpy的使用

 strcpy函数模拟实现 

strncpy的使用 

strcat 与 strncat 

strcat的使用

strcat函数模拟实现 

strncat的使用 

strcmp 与strncmp 

strcmp的使用

strcmp函数模拟实现 

strncmp的使用 


 

字符分类函数

导图


函数介绍 

1.getchar

看下列代码:输入字符,判断大小写

int main()
{
	//接收字符
	char ch = getchar();
	if (ch >= 'a' && ch <= 'z')
	{
		printf("%c是小写\n", ch);
	}
	else if(ch > 'A' && ch < 'Z')
	{
		printf("%c是大写\n", ch);
	}
	return 0;
}

 控制台输出

 

2. isupper 和 islower

判断大小写

#include<ctype.h>
int main()
{
	int ch = getchar(); //接收字符串
	if (islower(ch))
	{
		printf("小写\n");
	}
	else if (isupper(ch))
	{
		printf("大写\n");
	}
	return 0;
}

字符转换函数:(toupper , tolower) 与 putchar

把下列字符串全部转换为大写/小写 

#include<ctype.h>
int main()
{
	char a[] = "I am a programmer and blogger named Bai Zihuan";
	int i = 0;
	while (a[i])
	{
		/*转为大写*/
		//if (islower(a[i]))
		//{

		//	a[i] -= 32;
		//}
		/*转为小写*/
		if (isupper(a[i]))
		{
			a[i] += 32;
		}
		putchar(a[i]);    //输出字符串
		i++;
	}
	printf("\n");
	return 0;
}

 

控制台输出显示 

 


字符串函数

导图

 string函数的使用和模拟实现

string的使用

注:

1..包含头文件 #include<string.h>

2.函数原型:size_t strlen( const char* str )

3.string返回类型为 size_t(无符号类型)

4.输出格式:%zd

 求字符串长度
#include<string.h>
int main()
{
	char a[] = "abcdef";
	size_t len = strlen(a);
	printf("%zd\n", len);
	return 0;
}

控制台输出:6 


 

字符串的比较 
#include<string.h>
int main()
{
	const char* a1 = "abcdefg";//字符串表达式,前加const,不可修改
	const char* a2 = "abcde";
	if (a1 - a2 > 0)
		printf("大于\n");
	else if (a1 - a2 < 0)
		printf("小于\n");
	else
		printf("等于\n");
	return 0;
}

控制台输出:大于 


string函数的模拟实现

1.计数方式

2.递归(不能创建临时变量)

3.指针 - 指针

//1.奇数方式
size_t my_strlen1(const char* str)
{
	size_t count = 0;
	assert(str);       //保证str为有效指针
	while (*str)       //*str != '\0'
	{
		count++;
		str++;
	}
	return count;
}

//2.递归(不能创建临时变量)
size_t my_strlen2(const char* str)
{
	assert(str);        //保证str为有效指针
	if (*str == '\0')
		return 0;
	else
		return 1 + my_strlen2(str + 1);
}

//3.指针-指针
size_t my_strlen3(const char* str)
{
	assert(str);         //保证str为有效指针
	const char* p = str; //用指针标记首字符地址
	while (*p)           //*p != '\0'
	{
		p++;
	}
	return p - str;      //字符末尾('\0'前一个字符) - 首字符

}

int main()
{
	const char* ch = "abcdefg";
	size_t ret = my_strlen3(ch);
	printf("%zd\n", ret);
	return 0;
}

 控制台显示输出:7


strcpy 与 strncpy

 strcpy的使用

函数原型:char* strcpy(char* destination,const char* source)

理解为:把参数source的字符串 拷贝(复制)destination 中去

                           (源字符串)                             (目标空间)

int main()
{
	char str1[20] = "xxxxxxxxx";
	char str2[] = "hello";
	strcpy(str1, str2);
	printf("%s\n", str1);
	return 0;
}

 

strcpy使用注意事项 

 


 strcpy函数模拟实现 

char* my_strcpy(char* str1, const char* str2)
{
	char* ret = str1;         //用指针标记str1首字符地址
	assert(str1 && str2);     //保证str1和str2为有效指针
	while (*str1++ = *str2++) //while循环直至*str1 = *str2
	{
		;
	}
	return ret;               //返回标记首字符地址
}

int main()
{
	char str1[20] = { 0 };
	char str2[] = "hello";
	my_strcpy(str1, str2);
	printf("%s\n", my_strcpy(str1, str2));
	return 0;
}

strncpy的使用 

函数原型:char* strncpy(char* destination,const char* source,size_t num )

int main()
{
	//拷贝复制 --strnpy
	char p1[20] = "xxxxxxxxx";
	char p2[] = "hello";
	strncpy(p1, p2, 3);

	return 0;
}

 

 


strcat 与 strncat 

strcat的使用

函数原型:char* strcat(char* destination,const char* source)

                                                destination <-- 追加    source

int main()
{
	char a[15] = "programmer ";
	char a1[] = "Bai";
	char* ret = strcat(a, a1);
	printf("%s\n", a);
	return 0;
}

 控制台输出显示 

 

 注意事项与调试步骤


strcat函数模拟实现 

char* my_strcat(char* str1, const char* str2)
{
	char* p = str1;         //标记str1首字符串的地址
	assert(str1 && str2);   //保证str1和str2为有效指针
	//while循环追加
	while (*str1)
	{
		str1++;
	}
	//拷贝
	while ((*str1++ = *str2++))
	{
		;
	}
	return p;                //返回str1首字符地址
}

int main()
{
	char a[15] = "programmer ";
	char a1[] = "Bai";
	my_strcat(a, a1);
	printf("%s\n", a);
	return 0;
}

strncat的使用 

函数原型:char* strncat(char* destination,const char* source,size_t num )

int main()
{
	//追加  -- strncat
	char str1[20] = "hello ";
	char str2[] = "world";
	strncat(str1, str2, 3);
	
	return 0;
}

  注意事项与调试步骤


strcmp 与strncmp 

strcmp的使用

函数原型:int strcmp(const char* destination,const char* source)

int main()
{
	int ret = strcmp("abcdef", "abcf");

   
	if (ret > 0)
	{
		printf("大于\n");
	}
	else if (ret < 0)
	{
		printf("小于\n");
	}
	else
	{
		printf("等于\n");
	}
	return 0;
}

  代码解释

控制台结果显示:大于 


strcmp函数模拟实现 

int my_strcmp(const char* str1, const char* str2)
{
	assert(str1 && str2);  //保证str1和str2指针的有效性
	while (*str1 == *str2) //当str1和str2的解引用相等
	{
		if (*str1 == '\0')
			return 0;
		str1++;
		str2++;
	}
		return *str1 - *str2;
}

int main()
{
	int ret = my_strcmp("abcdef","abcdef");

	if (ret > 0)
	{
		printf("大于\n");
	}
	else if (ret == 0)
	{
		printf("等于\n");
	}
	else
	{
		printf("小于\n");
	}
	return 0;
}

strncmp的使用 

函数原型:int strncat(const char* str1,const char* str2,size_t num )

代码解释:

比较str1和str2的前num个字符,如果相等就继续往后比较,最多⽐较num个字⺟,

如果提前发现不⼀样,就提前结束,⼤的字符所在的字符串⼤于另外⼀个。

如果num个字符都相等,就是相等返回0.

int main()
{
	//比较 -- strncmp
	int ret = strncmp("abcde", "abcq", 5);
	if (ret > 0)
	{
		printf("大于\n");
	}
	else if (ret < 0)
	{
		printf("小于\n");
	}
	else
	{
		printf("等于\n");
	}
	return 0;
}

 

 ***********************************************************分割线*****************************************************************************
紧接和期待下文!!!
感谢浏览和阅读。

等等等等一下,分享最近喜欢的一句话:

“生活原本沉闷,但跑起来就有风”。

我是白子寰,如果你喜欢我的作品,不妨你留个点赞+关注让我知道你曾来过。
你的点赞和关注是我持续写作的动力!!! 
好了划走吧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1503631.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

苍穹外卖-day01

苍穹外卖-day01 目录 苍穹外卖-day01课程内容1. 软件开发整体介绍1.1 软件开发流程1.2 角色分工1.3 软件环境 2. 苍穹外卖项目介绍2.1 项目介绍2.2 产品原型2.3 技术选型 3. 开发环境搭建3.1 前端环境搭建3.2 后端环境搭建3.2.1 熟悉项目结构3.2.2 Git版本控制3.2.3 数据库环境…

【考研数学】129高分学姐二战经验+资料分享

21年数学三87分 22年数学三129分 可以说这两年该踩的雷我都踩了、该做的题我都做了。 进来看看是什么使我突然醒悟让我数学提分40多分的叭。 李林的880题我也做过&#xff0c;先来说说这本书的优缺点以及适用人群吧。 习题优点 李林老师的880题难度适中&#xff0c;很贴近…

013 Linux_互斥

前言 本文将会向你介绍互斥的概念&#xff0c;如何加锁与解锁&#xff0c;互斥锁的底层原理是什么 线程ID及其地址空间布局 每个线程拥有独立的线程上下文&#xff1a;一个唯一的整数线程ID, 独立的栈和栈指针&#xff0c;程序计数器&#xff0c;通用的寄存器和条件码。 和其…

基于springboot实现大学外卖管理系统项目【项目源码+论文说明】

基于springboot实现大学外卖管理系统演示 摘要 如今&#xff0c;信息化不断的高速发展&#xff0c;社会也跟着不断进步&#xff0c;现今的社会&#xff0c;各种工作都离不开信息化技术&#xff0c;更离不开电脑的管理。信息化技术也越来越渗透到各小型的企业和公司中&#xff…

pytorch(九)卷积神经网络

文章目录 卷积神经网络全连接神经网络与卷积神经网络的区别概念性知识mnist数据集(卷积神经网络) GoogLeNetInception 残差网络ResNet残差块结构 卷积神经网络 全连接神经网络与卷积神经网络的区别 全连接神经网络是一种最为基础的前馈神经网络&#xff0c;他的每一个神经元都…

AndroidStudio跑马灯实现

在activity_main.xml中编写如下代码&#xff1a; <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_h…

【考研数学】打基础,张宇《30讲》还是武忠祥《基础篇》?

张宇的30讲还是不太适合零基础的考研党去听...因为宇哥整体节奏较快&#xff0c;如果目标分较高&#xff0c;有一定的基础还是建议的 身边真的很多130-140的大佬都是跟着张宇从头到尾&#xff0c;张宇老师的习题册非常适合基础扎实&#xff0c;想冲刺高分的考研党 我是属于基…

R语言的数据类型与数据结构:向量、列表、矩阵、数据框及操作方法

R语言的数据类型与数据结构&#xff1a;向量、列表、矩阵、数据框及操作方法 介绍向量列表矩阵数据框 介绍 R语言拥有丰富的数据类型和数据结构&#xff0c;以满足各类数据处理和分析的需求。本文将分享R语言中的数据类型&#xff0c;包括向量、列表、矩阵、数据框等&#xff…

Skywalking官方的实战模拟项目Live-Demo

Skywalking 官方的实战模拟项目Live-Demo Live-Demo 是 Skywalking 官方的实战模拟项目&#xff0c;其中包含4个子模块项目 projectA访问projectB、projectC两个SpringBoot项目 projectB访问本地的H2数据库 projectC访问www.baidu.com并同时向一台Kafka消息队列写入数据 proje…

VSCODE解决git合并过程中的冲突问题;error: failed to push some refs to

1&#xff1a;异常现象 推送有冲突的git修改到远端的时候&#xff0c;会有如下提示 git.exe push --progress “origin” master:master To http://gitlab.xxx.com/dujunqiu/test.git ! [rejected] master -> master (fetch first) error: failed to push some refs to ‘…

解决“ModuleNotFoundError: No module named ‘RPi._GPIO‘”

背景描述 树莓派4B Ubuntu20.04 Python3.9安装RPi.GPIO后无法使用 解决办法 使用sudo pip3 install RPi.GPIO --upgrade尝试更新&#xff0c;发生红字报错&#xff0c;提示在编译过程中缺少Python开发头文件&#xff08;Python.h&#xff09;&#xff0c;因此应该先安装他&…

短视频矩阵系统--抖去推---年后技术还能迭代更新开发运营吗?

短视频矩阵系统#短视频矩阵系统已经开发3年&#xff0c;年后这个市场还能继续搞吗&#xff1f;目前市面上开发短视频账号矩阵系统的源头公司已经不多了吧&#xff0c;或者说都已经被市场被官方平台的政策影响的不做了吧&#xff0c;做了3年多的矩阵系统开发到现在真的是心里没有…

excel 动态列导出

excel动态列&#xff0c;只好用poi来写了&#xff0c;也并不复杂&#xff0c;一样就这个件事情抽像为几步&#xff0c;就是套路了&#xff0c;开发效率就上去了。 1 准备空模板 导出操作与excel模板的导出一样&#xff0c;可以参考excel导出标准化 2 自定义SheetWriteHandler …

TI IWR6843ISK ROS驱动程序搭建

1、设备准备 1.1 硬件设备 1&#xff09;TI IWR 6843 ISK 1块 2&#xff09;Micro USB 数据线 1条 1.2 系统环境 1&#xff09;VMware Workstation 15 Player 虚拟机 2&#xff09;Ubuntu18.04 并安装有 ROS1 系统 如若没有安装 ROS 系统&#xff0c;可通过如下指令进行…

HTML 02

1.列表 布局内容排列整齐的区域 (1)无序列表 写法&#xff1a; <ul><li>列表条目1</li><li>列表条目2</li><li>列表条目3</li></ul> 浏览器中显示&#xff1a; 注意&#xff1a; ul标签里只能包裹li标签 li标签里可以包…

算法学习系列(四十):贡献法

目录 引言概念一、孤独的照片二、牛的基因学三、字串分值 引言 关于这个贡献法考的不是很多&#xff0c;主要题型是出现在需要枚举每一个组合这类题&#xff0c;出现的次数较多。没有固定的模板&#xff0c;就是一种思想&#xff0c;跟贪心一样&#xff0c;每个题都是不一样的…

探讨系统测试的最佳实践与思维模式!

这是测试活动过程详解系列的最后一篇文章。之前的想法&#xff0c;是对测试过程各重要环节进行拆解&#xff0c;然后介绍这个环节重点要做的事情&#xff0c;为什么要做这些事&#xff0c;以及注意事项。 前面几篇文章分别介绍了单元测试、集成测试、回归测试阶段要解决的问题…

yolo模型中神经节点Mul与Sigmoid 和 Conv、Concat、Add、Resize、Reshape、Transpose、Split

yolo模型中神经节点Mul与Sigmoid 和 Conv、Concat、Add、Resize、Reshape、Transpose、Split 在YOLO&#xff08;You Only Look Once&#xff09;模型中&#xff0c;具体作用和用途的解释&#xff1a;

qt 日志 格式化打印 QMessagePattern

进入 qt源码 调试:qt creator debug 无法进入 qt源码 调试-CSDN博客 qt为 格式化打印 日志 提供了一个简易的 pattern(模式/格式) 词法解析类QMessagePattern,该类在qt的专门精心日志操作的源码文件Src\qtbase\src\corelib\global\qlogging.cpp 中 该类直接在构造函数中…

基于springboot+vue的食品安全管理系统(源码+论文)

目录 前言 一、功能设计 二、功能实现 1 首页 2 后台登录 3 食品信息添加页面 4 食品查询 三、库表设计 四、论文 前言 从事食品行业的商家可能会对于食品的储存以及食品的销售&#xff0c;都有着不同门道的想法&#xff0c;那么如何能将这些想法一一实现&#xff0c;…