(c语言进阶)字符串函数、字符分类函数和字符转换函数

一.求字符串长度

1.strlen()

(1)基本概念

头文件:<string.h>

(2)易错点:strlen()的返回值为无符号整形

#include<stdio.h>
#include<string.h>
int main() 
{const char* str1 = "abcdef";const char* str2 = "bbb";printf("%u\n", strlen(str2) - strlen(str1));printf("%d\n", strlen(str2) - strlen(str1));return 0;
}

 

两个strlen函数的返回值相减,得到的结果为无符号整数的形式

#include<stdio.h>
#include<string.h>
int main() 
{const char* str1 = "abcdef";const char* str2 = "bbb";if (strlen(str2) - strlen(str1) > 0){printf(">\n");}else{printf("<\n");}return 0;
}

 (3)模拟实现

#include<stdio.h>
#include<string.h>
size_t my_strlen(const char* str1)
{size_t count=0;while (*str1++){count++;}return count;
}
int main() 
{const char* str1 = "abcdef";size_t len=my_strlen(str1);printf("%u",len);return 0;
}

二.长度不受限制的字符串函数

1.strcpy()——将源字符串复制给目标字符串

(1)基本概念

头文件:<string.h>

#include<stdio.h>
#include<string.h>
int main()
{char name[20] = {0};//目标字符串的空间要足够大,否则会出现数组越界现象char arr[20] = "hhhhhhhhhh";strcpy(name,arr);//arr为字符串首元素的地址//strcpy(目标字符串首元素地址,字符串常量首元素地址)//'\0'也会被复制到目标字符串printf("%s\n",name);strcpy(name,"ycy");printf("%s",name);return 0;
}

(2)易错点:目标空间不够大时,字符串的复制还是会进行,代价是通过数组越界来实现的

(3)模拟实现

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strcpy(char* name,char* arr)
{assert(name&&arr);char* p = name;while (*name++=*arr++) //赋值语句的返回值为左操作数的值,当*arr将'\0'赋值给*name时结束循环{}return p;
}
int main()
{char name[20] = {0};char arr[20] = "hhhhhhhhhh";my_strcpy(name,arr);printf("%s",name);return 0;
}

 

2.strcat()——字符串追加

 (1)基本概念

头文件<string.h>

 (2)模拟实现

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strcat(char* arr1,char* arr2)
{char* p = arr1;//将地址移动至\0处while (*arr1){arr1++;}//从\0处开始拷贝arr2//h e l l o \0——arr1//  w o r l d \0——arr2//h e l l o  w o r l d \0 ——追加后的arr1while (*arr1++ = *arr2++){}return p;
}
int main()
{char arr1[20] = "hello";char arr2[20] = " world";my_strcat(arr1,arr2);printf("%s",arr1);return 0;
}

3.strcmp()——字符串比较

(1)基本概念

头文件<string.h> 

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{char arr1[20] = "hello";char arr2[20] = "world";int p=strcmp(arr1,arr2);//strcmp函数会将两个字符串的每个字符依次比较//若出现不相等则停止比较//前一个操作符的元素大于后一个操作符的元素,则会输出一个大于零的整数//前一个操作符的元素小于后一个操作符的元素,则会输出一个小于零的整数、//等于则输出0if (p > 0){printf("arr1>arr2\n");}else if (p == 0){printf("arr1==arr2\n");}else{printf("arr1<arr2\n");}return 0;
}

 (2)模拟实现

include<stdio.h>
#include<string.h>
#include<assert.h>
int my_strcmp(char* arr1,char* arr2)
{assert(arr1&&arr2);while (*arr1==*arr2) //相同的情况下,判断下一位是否也相同,不相同则退出循环{if (*arr1=='\0'||*arr2=='\0')  //若有其中一个字符串到达末尾,则退出循环{break;}arr1++;arr2++;}return *arr1 - *arr2;  //不相同则相减返回差值
}
int main()
{char arr1[20] = "hello";char arr2[20] = "hello";int p=my_strcmp(arr1,arr2);if (p > 0){printf("arr1>arr2\n");}else if (p == 0){printf("arr1==arr2\n");}else{printf("arr1<arr2\n");}return 0;
}

三.长度受限制的字符串函数介绍

1.strncpy() ——可控制,复制字符串元素

 (1)基本概念

头文件<string.h> 

#include<stdio.h>
#include<string.h>
int main()
{char arr1[20] = "abcdef";char arr2[] = "bit";strncpy(arr1,arr2,3);printf("%s\n",arr1);return 0;
}

 (2)易错点:当要复制的元素个数大于原字符串时,多出来的位置会用\0代替

#include<stdio.h>
#include<string.h>
int main()
{char arr1[20] = "abcdef";char arr2[] = "bit";strncpy(arr1,arr2,5);printf("%s\n",arr1);return 0;
}

 (3)模拟实现

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strncpy(char* arr1,char* arr2,size_t x)
{assert(arr1&&arr2);	char *p= arr1;int i;int len = strlen(arr2);for (i = 0; i < x; i++){if (i>len){*arr1++ = '\0';}else{*arr1++ = *arr2++;}}return p;
}
int main()
{char arr1[20] = "abcdef";char arr2[] = "bit";my_strncpy(arr1,arr2,5);printf("%s\n",arr1);return 0;
}

2.strncat()——可控制,链接字符串元素

(1)基本概念 

头文件<string.h> 

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{char arr1[20] = "hello";char arr2[] = "bit";strncat(arr1,arr2,3);printf("%s\n",arr1);return 0;
}

(2)易错点:需要链接的元素个数小于原字符串时,会在链接相应数量元素的同时多链接一个'\0' .元素个数大于原字符串时,不会用'\0'填补

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{char arr1[20] = "hello";char arr2[] = "bit";strncat(arr1,arr2,5);printf("%s\n",arr1);return 0;
}
#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{char arr1[20] = "hello";char arr2[] = "bit";strncat(arr1,arr2,1);printf("%s\n",arr1);return 0;
}

(3)模拟实现 

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strncat(char* arr1,char*arr2,size_t x)
{assert(arr1&&arr2);int len = strlen(arr2);char* p = arr1;while (*arr1 != '\0'){arr1++;}if (x >= len){while (*arr2){*arr1++ = *arr2++;}}else{for (int i = 0; i < x; i++){*arr1++ = *arr2++;}*arr1 = '\0';}return p;
}
int main()
{char arr1[20] = "hello";char arr2[] = "bit";my_strncat(arr1,arr2,5);printf("%s\n",arr1);return 0;
}

3.strncmp()——可控制,比较字符串元素 

 (1)基本概念

头文件<string.h> 

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{char arr1[20] = "hello";char arr2[] = "bit";int ret=strncmp(arr1,arr2,3);if (ret > 0){printf("arr1>arr2");}else if (ret == 0){printf("arr1==arr2");}else{printf("arr1<arr2");}return 0;
}

四.字符串查找

1.strstr()——在一个字符串中查找另一个字符串是否存在

 (1)基本概念

头文件<string.h> 

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{char arr1[20] = "hello bit world";char arr2[] = "bit";char*ret = strstr(arr1,arr2);//ret为寻找到字串位置的首地址if (ret == NULL){printf("所寻找的子串不存在\n");}else{printf("%s",ret);//从地址处往后输出}return 0;
}

 (2)模拟实现

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strstr(const char* str1, const char* str2)
{assert(str1&&str2);  //判断参数不为空const char* s1 = str1;const char* s2 = str2;const char* p = str1;while (*p) //被查找的字符串不为空{s1 = p;s2 = str2;  //始终指向查找字符串的首元素地址while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2)  //都不为空且相等时进入循环{s1++;s2++;}if (*s2 == '\0') //如果退出循环时查找字符串到最后都是相等的,则说明查找成功{return p; //返回查找到的首地址}p++; //若查找途中存在不相同的,则被查找字符串指针向后一位}return NULL;
}
int main()
{char arr1[20] = "hello bit world";char arr2[] = "bit";char* ret = my_strstr(arr1, arr2);//ret为寻找到字串位置的首地址if (ret == NULL){printf("所寻找的子串不存在\n");}else{printf("%s", ret);//从地址处往后输出}return 0;
}

 

2.strtok()——切割字符串

 (1)基本概念

头文件<string.h> 

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{const char* sep = '@';  //分隔符char email[] = "zhangpengwei@bietejieyeke.com";  //被分割的字符串strtok(email,sep); //因为strtok函数会将遇到的第一个分隔符改为'\0',
//并返回分隔符的指针,将改变原有字符串
//__________________________________________________________________________________//若不想原有字符串被改变则采用如下操作char cp[] = {0};strcpy(cp,email);strtok(cp,sep);return 0;
}

 (2)简单应用

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{const char* sep = "@.";  //分隔符char email[] = "zhangpengwei@bietejieyeke.com";  //被分割的字符串char cp[30] = {0};strcpy(cp,email);  //strtok函数有记忆功能,执行完后会保存上一个分隔符的地址,下一次调用时从该地址往后查找char* ret=strtok(cp,sep);printf("%s\n",ret);ret = strtok(NULL,sep);  //所以除第一次调用,多次调用时不需要传入参数,所以传入NULLprintf("%s\n", ret);ret = strtok(NULL, sep);printf("%s\n", ret);return 0;
}

 (3)优化

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{const char* sep = "@.";  //分隔符char email[] = "zhangpengwei@bietejieyeke.com";  //被分割的字符串char cp[30] = {0};strcpy(cp,email);  char* ret = NULL;for (ret = strtok(cp, sep); ret != NULL; ret=strtok(NULL, sep)){printf("%s\n",ret);}return 0;
}

五.错误信息报告

1.strerror()——返回错误码所对应的错误信息

 (1)基本概念

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{//c语言的库函数在执行失败的时候,都会设置相应的错误码//0 1 2 3 4 5 6 7 8 ......//strerror()可以返回错误码所对应的错误信息printf("%s\n", strerror(1));printf("%s\n", strerror(2));printf("%s\n", strerror(3));printf("%s\n", strerror(4));printf("%s\n", strerror(5));printf("%s\n", strerror(6));printf("%s\n", strerror(7));printf("%s\n", strerror(8));return 0;
}

 (2)简单应用

#include<stdio.h>
#include<string.h>
#include<assert.h>
#include<errno.h>
int main()
{//打开文件的函数为fopen()//"r"表示以读的形式打开//返回的是FILE型的指针,如果打开失败会返回空指针(NULL)FILE* pf = fopen("text.txt","r");//若打开的文件在程序路径下,可以使用相对路径(文件名)fopen("C:\\Users\\admin\\Desktop\\text2.text","r");//在其他位置要使用绝对路径,单个'\'会被识别为转义字符,所以要再加一个'\'//打开文件失败后,fopen函数会将错误码存储在errno中//errno—C语言设置的一个全局的错误码存储变量//只要发生错误,都会把错误码存在errno中—始终记录最新的错误码//调用errno需要应用头文件<errno.h>if (pf == NULL){printf("%s", strerror(errno));}return 0;
}

六.字符分类函数 ——头文件<ctype.h>

重点:应用

举例:isspace()——判断空白字符

#include<stdio.h>
#include<string.h>
#include<ctype.h>
int main()
{printf("%d\n", isspace('x'));printf("%d\n", isspace(' '));return 0;
}

1、iscntrl()——判断是否是控制字符(任何控制字符)

功能 

判断是否是控制字符(任何控制字符)

返回值

若返回值为非0数字,则为控制字符,若返回0,则不是控制字符。

2、isspace()——判断是否是空白字符

功能:

判断是否是空白字符(空格、换页/f、换行\n,回车\r,制表符\t或者垂直制表符\v)

返回值:

若返回值为非0数字,则为空白字符,若返回0,则不是空白字符。

3、isdigit()——判断是否是十进制数字字符

功能:

判断是否是十进制数字字符(0-9)

返回值:

若返回值为非0数字,则为十进制数字字符,若返回0,则不是十进制数字字符。


4、isxdigit()——判断是否是十六进制数字字符

功能:

判断是否是十六进制数字字符(包括所有十进制数字,小写字母a-f,大写字母A-F)

返回值:

若返回值为非0数字,则为十六进制字符,若返回0,则不是控制字符。

5、islower()——判断是否是小写字母

功能:

判断是否是小写字母(a-z)

返回值:

若返回值为非0数字,则为小写字母字符,若返回0,则不是小写字母字符


6、isupper()——判断是否是大写字母

功能:

判断是否是大写字母(A-Z)

返回值:

若返回值为非0数字,则为大写字母字符,若返回0,则不是大写字母字符。


7、isalpha()——判断是否是字母字符

功能:

判断是否是字母字符(a-z或A-Z)

返回值:

返回值为非0数字则为控制字符,返回0则不是控制字符。


8、isalnum()——判断是否是字母字符或者数字字符

功能:

判断是否是字母字符或者数字字符(a-z、A-Z、0-9)

返回值:

若返回值为非0数字,则为字母字符或数字字符,若返回0,则不是字母字符或数字字符。


9、ispunct()——判断是否是标点符号字符

功能:

判断是否是标点符号字符(任何不属于数字或字母的图形字符)

返回值:

若返回值为非0数字,则为标点符号,若返回0,则不是标点符号。


10、isgraph()——判断是否是图形字符

功能:

判断是否是图形字符(任何图形字符)

返回值:

若返回值为非0数字,则为图形字符,若返回0,则不是图形字符。


11、isprint()——判断是否是可打印字符

功能:

判断是否是可打印字符(包括图形字符和空白字符)

返回值:

若返回值为非0数字,则为可打印字符,若返回0,则不是可打印字符。

 七.字符转换函数

1.tolower(int c) ——字符转小写

#include<stdio.h>
#include<string.h>
#include<ctype.h>
int main()
{printf("%c\n",tolower('H'));return 0;

 

2.toupper(int c) ——字符转大写

#include<stdio.h>
#include<string.h>
#include<ctype.h>
int main()
{printf("%c\n",toupper('h'));return 0;

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

N-129基于springboot,vue学生宿舍管理系统

开发工具&#xff1a;IDEA 服务器&#xff1a;Tomcat9.0&#xff0c; jdk1.8 项目构建&#xff1a;maven 数据库&#xff1a;mysql5.7 系统分前后台&#xff0c;项目采用前后端分离 前端技术&#xff1a;vuevue-element-admin 服务端技术&#xff1a;springboot,mybatis…

css矩形盒子实现虚线流动边框+css实现step连接箭头

由于项目里需要手写步骤条 且实现指定状态边框虚线流动效果&#xff0c;故使用css去绘制步骤条连接箭头和绘制边框流动效果 效果&#xff1a; 1.绘制步骤条连接箭头 <ul class"process-list"><div v-for"(process, index) in processes" :key&qu…

论文阅读——DistilBERT

ArXiv&#xff1a;https://arxiv.org/abs/1910.01108 Train Loss: DistilBERT&#xff1a; DistilBERT具有与BERT相同的一般结构&#xff0c;层数减少2倍&#xff0c;移除token类型嵌入和pooler。从老师那里取一层来初始化学生。 The token-type embeddings and the pooler a…

UEditorPlus v3.6.0 图标补全,精简代码,快捷操作重构,问题修复

UEditor是由百度开发的所见即所得的开源富文本编辑器&#xff0c;基于MIT开源协议&#xff0c;该富文本编辑器帮助不少网站开发者解决富文本编辑器的难点。 UEditorPlus 是有 ModStart 团队基于 UEditor 二次开发的富文本编辑器&#xff0c;主要做了样式的定制&#xff0c;更符…

Wpf 使用 Prism 实战开发Day03

一.实现左侧菜单绑定 效果图: 1.首先需要在项目中创建 mvvm 的架构模式 创建 Models &#xff0c;放置实体类。 实体类需要继承自Prism 框架的 BindableBase&#xff0c;目的是让实体类支持数据的动态变更! 例如: 系统导航菜单实体类 / <summary>/// 系统导航菜单实体类…

CAD需要学c语言嘛?

CAD需要学c语言嘛&#xff1f; AutoCAD 和 C 语言没有关系的。 如果非要说是 AutoCAD 和哪个编程语言有关系&#xff0c;那应该是 VBA, 可以通过 VBA 编程&#xff0c;最近很多小伙伴找我&#xff0c;说想要一些c语言资料&#xff0c;然后我根据自己从业十年经验&#xff0c;熬…

关于安科瑞交流多回路智能电量采集监控装置在某高速项目的实际应用分析-安科瑞 蒋静

1项目背景 河南安阳林州市某高速公路项目是河南省政府主要打造的一项公路建设项目&#xff0c;该项目全长约70公里&#xff0c;起点位于安阳市内&#xff0c;终点位于林州市县。 该项目的建设旨在缓解当地交通压力&#xff0c;提高区域交通运输能力和服务水平&#xff0c;促进…

竞赛 深度学习卷积神经网络垃圾分类系统 - 深度学习 神经网络 图像识别 垃圾分类 算法 小程序

文章目录 0 简介1 背景意义2 数据集3 数据探索4 数据增广(数据集补充)5 垃圾图像分类5.1 迁移学习5.1.1 什么是迁移学习&#xff1f;5.1.2 为什么要迁移学习&#xff1f; 5.2 模型选择5.3 训练环境5.3.1 硬件配置5.3.2 软件配置 5.4 训练过程5.5 模型分类效果(PC端) 6 构建垃圾…

Ubuntu 诞生 19 年

导读2004 年 10 月 20 日&#xff0c;Ubuntu 4.10 正式发布&#xff0c;代号‘Warty Warthog’。 作为 Ubuntu 第一个版本&#xff0c;4.10 问世后立刻受到广大 Linux 用户欢迎。它搭载了当时最新的 GNOME 2.8 桌面环境&#xff0c;以及一系列实用软件&#xff0c;比如 Mozilla…

一带一路10周年:爱创科技加速中国药企国际化征程

“源自中国&#xff0c;属于世界”。 共建“一带一路”倡议提出10周年来&#xff0c;中国与沿线国家经济深度融合&#xff0c;在共商共建共享的基本原则下&#xff0c;“一带一路”形成了国际合作的平台和机制&#xff0c;跨国经济合作已基本形成。 随着“一带一路”合作日益加…

react中的useState和useImmer的用法

文章目录 一、useState1. 更新基本类型数据2. 更新对象3. 更新嵌套对象4. 更新数组5.更新数组对象 二、Immer1. 什么是Immer2. 使用use-immer更新嵌套对象3. 使用useImmer更新数组内部的对象 一、useState react中文官网教程 1. 更新基本类型数据 在函数式组件中&#xff0c…

IPv6+ 3.0关键技术解析与应用实践探索

IPv6作为面向5G和云计算的智能IP技术&#xff0c;其核心是以IPv6技术架构为底座&#xff0c;并基于用户的新兴业务进行创新发展而来的。任何一项技术创新的背后都有一只看不见的推手-用户的需求&#xff0c;也就是用户的业务发展所需&#xff0c;进一步来说是用户的应用系统在驱…

【广州华锐互动】牛顿运动定律VR虚拟教学软件

在科技日新月异的今天&#xff0c;虚拟现实&#xff08;VR&#xff09;技术已经逐渐渗透到各个领域&#xff0c;为我们带来了前所未有的沉浸式体验。在教育领域&#xff0c;VR技术的应用也日益广泛&#xff0c;尤其是在物理教学中&#xff0c;牛顿运动定律VR虚拟教学软件为学生…

分析Python招聘数据,可视化展示招聘信息详情

嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~! python更多源码/资料/解答/教程等 点击此处跳转文末名片免费获取 一. 数据来源分析 明确需求 明确采集网站以及数据内容 数据: 职位信息 网址: https://we.51job.com/pc/search?keywordpython&searchType3&sortType0&am…

Python通过pyecharts对爬虫房地产数据进行数据可视化分析(一)

一、背景 对Python通过代理使用多线程爬取安居客二手房数据&#xff08;二&#xff09;中爬取的房地产数据进行数据分析与可视化展示 我们爬取到的房产数据&#xff0c;主要是武汉二手房的房源信息&#xff0c;主要包括了待售房源的户型、面积、朝向、楼层、建筑年份、小区名称…

删除Win11文件管理器左侧的‘主文件夹‘和‘图库‘的链接.

删除Win11文件管理器左侧的主文件夹和图库的链接.删除步骤&#xff1a; * 1. win r 打开运行&#xff0c; 输入"regedit"打开注册表. * 2. 删除注册表: HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Desktop\NameSpace_xxxxxxxNameSpace…

使用WebStorm创建和配置TypeScript项目

创建 这里我用的是WebStorm 2019.2.2版本 首先&#xff0c;创建一个空项目 File -> New -> Project->Empty Project生成配置文件 自动配置&#xff1a; 打开终端输入tsc --init&#xff0c;即可自动生成tsconfig.json文件 手动配置&#xff1a; 在项目根目录下新建一…

Capacitor 打包 h5 到 Android 应用,uniapp https http net::ERR_CLEARTEXT_NOT_PERMITTED

Capacitor 打包 h5 到 Android 应用&#xff0c;uniapp https http net::ERR_CLEARTEXT_NOT_PERMITTED capacitor 官网&#xff1a; https://capacitorjs.com/docs/ 项目上需要做一个 app&#xff0c;而这个 app 是用 uniapp 做的&#xff0c;里面用到了一个依赖 dom 的库&…

腾讯云轻量应用服务器“镜像”怎么选择合适?

腾讯云轻量应用服务器镜像怎么选择&#xff1f;如果是用来搭建网站可以选择宝塔Linux面板腾讯云专享版&#xff0c;镜像系统根据实际使用来选择&#xff0c;腾讯云百科txybk.com来详细说下腾讯云轻量应用服务器镜像的选择方法&#xff1a; 腾讯云轻量应用服务器镜像选择 轻量…

Ansys Speos|Optimization小工具快速优化设计

概述 优化是一个有助于找到一个光学系统的最佳解决方案的实验过程&#xff0c;它主要是利用参数的变化而试图达到预期的结果。在Speos 2023 R2中提供三种可供选择的方法来执行此类分析。第一个是基于workbench创建的优化&#xff0c;可以参考文章&#xff08;基于Ansys Workben…