文章目录
前言
众所周知,字符串函数是我们在学习C语言过程中使用频率很高的一类库函数。本文列举了我们在C语言早期学习过程中常用到的字符串函数及其用法,并附上了与字符串函数相关的PTA例题及解析,题目难度较低,希望在看过本文对字符串的讲解后,能对大家有所帮助!
一、常见字符串函数详解
1.gets
字符串输入函数
形式:gets(字符数组)
#include <stdio.h>
int main()
{
char str[20];
gets(str);//输入字符串
return 0;
}
注意:输入带有空格的字符串,不能使用scanf(),要用gets()。
如果一定要用scanf(),则以scanf("%[^\n]%c,str)形式进行输入。输入效果与gets()等效。
2.puts
字符串输出函数
形式:puts(字符数组)
#include <stdio.h>
int main()
{
char str[20];
gets(str);//输入字符串
puts(str);//输出字符串,以'\0'为结束
return 0;
}
附运行截图
注意:gets、puts函数都是标准输入输出,包含在头文件<stdio.h>中,除gets、puts以外,使用字符串函数需要包含头文件<string.h>。
3.strlen
计算字符串长度的函数
计算的是字符串实际长度,不包括’\0’!
#include <stdio.h>
#include <string.h>
int main()
{
char str1[20] = "I love you!";//定义字符数组str1
int n = strlen(str1);//定义一个整形变量n,用于接受函数的返回值
printf("%d\n", n);
return 0;
}
或者直接测量:
#include <stdio.h>
#include <string.h>
int main()
{
int n = strlen("I love you!");//定义一个整形变量n,用于接受函数的返回值
printf("%d\n", n);
return 0;
}
附运行截图
4.strcat
字符串连接函数
形式:strcat(字符串1,字符串2)
作用:将两个字符数组中的字符串连接起来,把字符串2连接到字符串1后面,结果存储在字符数组1中。
#include <stdio.h>
#include <string.h>
int main()
{
char str1[10] = "I love";//定义字符数组str1
char str2[10] = " you!";//定义字符数组str2
strcat(str1, str2);//strcat将str2连接到str1后面,并将结果存储到str1中
printf("%s\n", str1);//输出str1
return 0;
}
附运行截图
5.strcpy与strncpy
字符串复制函数
形式:strcpy(字符数组1,字符串2)
作用:将字符串2复制到字符数组1中去。(直接覆盖!注意不是连接!)
#include <stdio.h>
#include <string.h>
int main()
{
char str1[10] = " ";//定义空数组str1
char str2[10] = "I love you!";//定义字符数组str2
strcpy(str1, str2);//strcpy将str2复制到str1中,并将结果存储到str1中
printf("%s\n", str1);//输出str1
return 0;
}
附运行截图
字符串选择复制函数
形式:strncpy(字符串1,字符串2,n)
作用(n的含义):将字符串2中的n个单个字符复制到字符数组1中,最少为0个,最多不能超过字符串2的长度。
#include <stdio.h>
#include <string.h>
int main()
{
char str1[20] = " ";//定义空数组str1
char str2[20] = "I love you!";//定义字符数组str2
strncpy(str1, str2, 6);//strncpy将str2中6个字符复制到str1中,并将结果存储到str1中
printf("%s\n", str1);//输出str1
return 0;
}
附运行截图
6.strcmp与strncmp
字符串比较函数 (注意:字符串不能用“==”比较,需用字符串比较函数strcmp)
形式:strcmp(字符串1,字符串2)
规则:两个字符串从左到右逐个字符相比(按ASCⅡ码值大小比较),直到出现不同的字符或遇到’\0’为止。如果全部字符相同,则认为两个字符串相等;如果出现不相同的字符,则以第一对不相同的字符比较结果为准,比较的结果由函数值带回。
①字符串1与字符串2相同,返回0
#include <stdio.h>
#include <string.h>
int main()
{
char str1[10] = "abcde";//定义字符数组str1
char str2[10] = "abcde";//定义字符数组str2
int n = strcmp(str1, str2);//定义一个整形变量n,用于接受函数的返回值
printf("%d\n", n);
return 0;
}
附运行截图
②字符串1>字符串2,则返回一个正数
#include <stdio.h>
#include <string.h>
int main()
{
char str1[10] = "abdde";//定义字符数组str1
char str2[10] = "abcde";//定义字符数组str2
int n = strcmp(str1, str2);//定义一个整形变量n,用于接受函数的返回值
printf("%d\n", n);
return 0;
}
附运行截图(‘d’>‘c’,故str1>str2)
③字符串1<字符串2,则返回一个负数
#include <stdio.h>
#include <string.h>
int main()
{
char str1[10] = "abbde";//定义字符数组str1
char str2[10] = "abcde";//定义字符数组str2
int n = strcmp(str1, str2);//定义一个整形变量n,用于接受函数的返回值
printf("%d\n", n);
return 0;
}
附运行截图(‘b’<‘c’,故str1<str2)
字符串选择比较函数
形式:strncmp(字符串1,字符串2,n)
作用:选择字符串2中的前n个字符与字符串1进行比较。比较规则与strcmp相同。
7.strstr与strchr
字符串查找函数
形式:char *strstr(字符串1,字符串2)
作用:用于判断字符串2是否为字符串1的子串,若是,则返回字符串2在字符串1中首次出现的地址,若不是,则返回NULL。
①str2是str1的子串
#include <stdio.h>
#include <string.h>
int main()
{
char str1[10] = "abcdefg";//定义字符数组str1
char str2[10] = "efg";//定义字符数组str2
char *ret = strstr(str1, str2);//定义ret用于接受函数返回值
printf("%s\n", ret);
return 0;
}
附运行截图
②str2不是str1的子串
#include <stdio.h>
#include <string.h>
int main()
{
char str1[10] = "abcdefg";//定义字符数组str1
char str2[10] = "aef";//定义字符数组str2
char *ret = strstr(str1, str2);//定义ret用于接受函数返回值
printf("%s\n", ret);
return 0;
}
附运行截图
strchr
字符查找函数
形式:char *strchr(字符串,字符)
作用:从字符串的首地址开始查找字符串中首次出现字符的位置。
8.strupr
转换字符串为大写的函数
形式:strupr(字符串)
#include <stdio.h>
#include <string.h>
int main()
{
char str[10] = "aBCdEfG";//定义一个含大小写字母的字符数组
strupr(str);//使用strupr将str中的小写字母都转换成大写字母
printf("%s\n", str);
return 0;
}
附运行截图
9.strlwr
转换字符串为小写的函数
形式:strlwr(字符串)
#include <stdio.h>
#include <string.h>
int main()
{
char str[10] = "aBCdEfG";//定义一个含大小写字母的字符数组
strlwr(str);//使用strlwr将str中的大写字母都转换成小写字母
printf("%s\n", str);
return 0;
}
附运行截图
二、PTA例题详解
1.L1-070 吃火锅
以上图片来自微信朋友圈:这种天气你有什么破事打电话给我基本没用。但是如果你说“吃火锅”,那就厉害了,我们的故事就开始了。
本题要求你实现一个程序,自动检查你朋友给你发来的信息里有没有 chi1 huo3 guo1。
输入格式:
输入每行给出一句不超过 80 个字符的、以回车结尾的朋友信息,信息为非空字符串,仅包括字母、数字、空格、可见的半角标点符号。当读到某一行只有一个英文句点 . 时,输入结束,此行不算在朋友信息里。
输出格式:
首先在一行中输出朋友信息的总条数。然后对朋友的每一行信息,检查其中是否包含 chi1 huo3 guo1,并且统计这样厉害的信息有多少条。在第二行中首先输出第一次出现 chi1 huo3 guo1 的信息是第几条(从 1 开始计数),然后输出这类信息的总条数,其间以一个空格分隔。题目保证输出的所有数字不超过 100。
如果朋友从头到尾都没提 chi1 huo3 guo1 这个关键词,则在第二行输出一个表情 -_-#。
输入样例1:
Hello!
are you there?
wantta chi1 huo3 guo1?
that’s so li hai le
our story begins from chi1 huo3 guo1 le
.
输出样例1
5
3 2
输入样例2
Hello!
are you there?
wantta qi huo3 guo1 chi1huo3guo1?
that’s so li hai le
our story begins from ci1 huo4 guo2 le
.
输出样例2
5
-_-#
题目引用自团体程序设计天梯赛真题(2020年)。
C语言代码实现:
1.标记数组法(常用且推荐)
#include <stdio.h>
#include <string.h>
int main()
{
char infor[82];//用于存储输入的信息
int cnt = 0, cnt1 = 0;//cnt用于记录信息总条数,cnt1用于记录厉害信息总条数
int arr[102] = { 0 };//用于记录厉害信息出现的条数
while (gets(infor) && strcmp(infor, ".") != 0)//注意要用gets函数,一定不能用scanf(遇空格就停止)
{
cnt++;//信息的总条数
char* ret = strstr(infor, "chi1 huo3 guo1");//使用字符串比较函数,返回值存储在ret中
if (ret != NULL)//不是子串返回NULL,是子串则不返回NULL
{
cnt1++;//这类信息总条数
arr[cnt] = 1;//将该信息出现的条数作为下标,该下标对应的元素标记为1
}
}
printf("%d\n", cnt);
int i = 0, flag = 0;//引入标志变量flag判断有无厉害信息
for (i = 0; i < 102; i++)//遍历arr数组,看有无厉害信息
{
if (arr[i] == 1)//为1,则被标记过
{
flag = 1;//有厉害信息
printf("%d %d", i, cnt1);
break;//要求只输出第一次出现厉害信息是第几条
}
}
if (flag == 0)//没有厉害信息
{
printf("-_-#");
}
return 0;
}
2.无限循环遍历法
#include <stdio.h>
#include <string.h>
int main()
{
char str[105];//用于存储输入信息
char flag[20] = "chi1 huo3 guo1";//单独存放厉害信息
int flag1 = 0, flag2 = 0, count = 0;
while(1)//无限循环
{
gets(str);//用gets输入字符串
if (strcmp(str, ".") == 0)
{
break;//使用字符串查找函数,读到"."时结束输入,跳出循环
}
count++;//count统计信息总条数
if (strstr(str, flag) != NULL)//出现厉害信息
{
flag1++;//flag1统计厉害信息出现条数
if (flag2 == 0)//第一次出现
{
flag2 = count;//flag2用于存储第一次出现厉害信息的信息条数
}
}
}
printf("%d\n", count);
if (flag1 == 0)
{
printf("-_-#");//没有厉害信息
}
else
{
printf("%d %d", flag2, flag1);
}
return 0;
}
两种方法提交结果都正确:
总结
今天我们学习了C语言中常用字符串函数的用法,并附上一道简单的例题作为实战教学,希望能对大家有所帮助!