/*
在一个字符串中进行搜索,查找所有在一个给定字符集和中出现的字符.这个函数的原型应该如下:
char *fine_char(char const *source, char const *chars);
函数是查找source字符串中匹配chars字符串中任何字符的第一个字符,函数然后返回一个指向source中第一个匹配所找到的位置的指针
如果source中的所有字符均不匹配chars中的人物字符,函数就返回一个NULL指针,如果任何一个参数为NULL,或任何一个参数所指向的字符串为空,
函数也返回一个NULL指针*/
这是一个points on C中第六章编程练习的第一题..如何去运用指针去操作数组,
所以要求有
a.不应该使用任何用于操纵字符串的库函数(如strcpy,strcmp,index等).
b.函数中的任何地方都不应该使用下标引用.
这个函数可以提现出在指针和数组中如何去转化,
例如:
char a[]="hello world!";
char *p;
//给指针赋值
p=a; //方法一
//p=&a; //方法二
//p=a[0]; //方法三
指针和数组的对应关系
指针指向字符数组a的首地址,方法一和方法二.
指针指向字符数组a[0]的地址,a[0]的地址和数组a的首地址是相同的,所以可视为数组a的首地址.
在使用的时候*p可视为a[0],例如:printf("%c",*p);和printf("%c",a[0]);是一样的.
*(p+i) 和a[i]都指向数组中的同一个值,即*(p+i) == a[i];
理解这些之后,题目的要求就可以解答出来了
用两个循环嵌套来查找source字符串中所匹配chars字符串中的字符第一个字符,只要相匹配,则