题目1
题目:请编写一个函数,它在字符串中进行搜索,查找所有在一个给定字符集合中出现的字符。这个函数的原型应该如下:
char *find_char(char const *source, char const *chars);
它的基本想法是查找source字符串匹配chars字符串中任何字符的第一个字符,函数然后返回一个指向source中国第一个匹配所找到的位置的指针。如果source中的所有字符均不匹配chars中的任何字符,函数就返回一个NULL指针。如果任何一个参数为NULL,或任何一个参数所指向的字符串为空,函数也返回一个NULL指针。
举个例子,假定source指向ABCDEF。如果chars指向XYZ,JURY或者QQQQ,函数就返回一个NULL指针。如果chars指向XRCQEF,函数就返回一个指向source中C字符的指针。参数所指向的字符串时绝不会被修改的。
碰巧,C函数库中存在一个名叫strpbrk 的函数,它的功能几乎和你要编写的函数一模一样。但这个程序的目的是让你自己练习操纵指针,所以:
a:你不应该使用任何用于操纵字符串的库函数(如strcpy,strcmp,index等);
b:函数中的任何地方都不应该使用下标引用。
思路:双循环遍历源串和目标串,依次进行比较,判断是否相等。
代码如下:
#include<stdio.h>
#include<string.h>
char *find_char(char const *source, char const *chars)
{
char *tempSource = source;
/*
** 参数检查
*/
if (source == NULL || chars == NULL)
{
return NULL;
}
if (*source == '