从一个字符串数组中,查找有没有给定的字符串,如果有,返回其索引,如果没有,返回-1
考查要点:
第一、字符串比较函数strcmp,如果两个字符串相同,返回0,如果不相同,返回非0(根据第一个不相同的字符的ascii比较来看,如果前面的大于后面,返回值>0,反之,则返回值<0);
第二、字符串数组的遍历; 实际考查的是获取字符串数组的长度,len = sizeof(array) / sizeof(array[0])
示例代码如下:
#include <stdio.h>
#include <string.h>
//从指定字符串数组strs中查询是否存在字符串str
//返回str在数组中的索引
//利用字符串比较函数strcmp
//注意事项:如何遍历字符串数组,使用通用方法获取字符串数组长度
// len = sizeof(strs) / sizeof(strs[0])
//这里还有个考点,就是sizeof指针和sizeof数组名是有区别的,这个一定要注意
//必须在主函数中计算字符串数组的长度,因为数组名传递参数的时候,实际是作为指针进行传递的
//定义获取字符串数组长度的宏
#define GET_ARRAY_LEN(array,len) {len = (sizeof(array) / sizeof(array[0]));}
static int find_string(char *strs[], char *str, int len)
{
int i = 1;
while(i < len + 1){
if(strcmp(*strs, str) =