BSP Day 22

字符串的一些函数和它的实现

1.strlen

定义:计算数组中‘\0’之前的字符的长度。

函数实现它

#include<stdio.h>
 
int my_strlen(char* str)
{
	char* tmp = str;
	while (*str != '\0')
	{
		str++;
	}
	return str - tmp;
}
 
int main()
{
	char arr[] = "abcedf";
	printf("%d\n", my_strlen(arr));
	return 0;
}

2. strcpy

定义:将源数组内容拷贝到目标数组中

特别注意!:strcpy会将源字符串的‘\0’拷贝到目标空间,目标空间要足够大,目标空间必须可变。

函数实现它

#include<stdio.h>
char* my_strcpy(char* dest, char* src)
{
	char* ret = dest;
	while (*dest++ = *src++)
	{
		continue;
	}
	return ret;
}
 
int main()
{
	char arr1[20] = { 0 };
	char arr2[] = "abcdef";
	printf("%s\n",my_strcpy(arr1,arr2));
	return 0;
}

3.strcat

将源字符串的内容追加到目标字符串空间中。从目标空间'\0'处 开始追加。

特别注意!:源字符串和目标字符串必须以‘\0’结束,目标空间必须足够大,目标空间必须可修改。

函数实现它

 void strcat_s (char *dest,char *src)
 {
 	int i = 0;
 	int n = strlen(dest);
 	while(src[i]!='\0')
 	{
 		dest[n+i] = src[i];
 		i++;
	 }
 }

 4.strcmp

定义: 比较两个字符串中对应位置上的字符大小,直到找到不同或'\0'。当str1>str2时,返回>0的数;当str1<str2时,返回<0的数;当str1=str2时,返回0。

函数实现

int strcmp_s(char *dest,char *src)
 {
 	int i = 0;
 	int n1 = strlen(dest);
 	int n2 = strlen(src);
 	int n;
 	if(n1>n2)
 	{
 		n = n2;
	 }
	 else
	 {
	 n = n1	;
	 }
	 while(i<=n)
	 {
	 	if(dest[i]>src[i])
		 {
		 	return 1;
		  } 
		  else if(dest[i]<src[i])
		  {
		  	return -1;
		  }
		  else
		  {
		  	i++;
		  }
	  } 
	  return 0;
 }

5.strstr

定义:在一个字符串中判断另一个字符串是不是该字符串的子串。

函数实现

#include<stdio.h>

char* my_strstr( char* str1, char* str2)
{

	char* s1 = str1;
	char* s2 = str2;
	char* cur = str1;
	while (*cur)
	{
		s1 = cur;
		s2 = str2;
		while (*s1 == *s2)
		{
			s1++;
			s2++;
		}
		if (*s2 == '\0')
		{
			return cur;
		}
		cur++;
	}
	return NULL;
}
 
int main()
{
	char arr1[] = "abcdefgh";
	char arr2[] = "cdef";
	char* ret = my_strstr(arr1, arr2);
	if (ret == NULL)
	{
		printf("找不到子串\n");
	}
	else
	{
		printf("%s\n",ret);
	}
	return 0;
}

6. strtok

定义:字符串切割,给定字符集,对源字符串的内容进行切割。

特别注意:strtok找到字符串中的一个标记,用‘\0’结尾,并且返回一个指向这个标记的指针;strtok会改变被操作字符串,建议使用时拷贝将内容到一个新的字符串里,保证源字符串不被修改。;传非NULL指针时,只找第一个标记;传NULL时,从保存好的位置往后找。

函数实现

char* strtok (char* str, const char* delim)
{
	// 生成替换字符表
	char table[256] = {0};
    while (*delim != '\0')
    {
        table[*delim] = 1;
        delim++;
    }

	// 使用 static 类型指针保存上一次函数调用时的字符串地址
	static char* pstr = NULL;
	if (str != NULL)
	{
		pstr = str;
	}

	// 保证 pstr 指向以非替换字符为首的子字符串
	while (*pstr != '\0' && table[*pstr] == 1)
	{
		pstr++;
	}	

	// ret 保存返回子字符串的首地址
	char* rst = (*pstr != '\0') ? pstr : NULL;

	while (*pstr != '\0')
	{
        if (table[*pstr] == 1)
        {
            // 切割得到子字符串,且 pstr 最后指向子字符串的下一字符
            *pstr++ = '\0';
            break;
        }
        else
        {
            pstr++;
        }
	}
    
	return rst;
}

7. strpbrk

strpbrk是在源字符串(s1)中找出最先含有搜索字符串(s2)中任一字符的位置并返回,若找不到则返回空指针。
返回s1中第一个满足条件的字符的指针,如果没有匹配字符则返回空指针NULL。

char  *find_char(char  *source,char  *chars)
{
    char  *stringChars  = NULL;//存储我们要查找的字符串
    if(source == NULL || chars ==NULL)
    {
        return NULL;
    }
    while(*source!='\0')
    {
        stringChars = chars;//始终将stringChars初始化为chars
        while(*stringChars != '\0')
        {
            if(*source==*stringChars)
            {
                return (char *)source;
            }
            stringChars++;
        }
        source++;
    }
}

 8.strcspn

顺序在字符串s1中搜寻与s2中字符的第一个相同字符,返回这个字符在S1中第一次出现的位置。

函数实现

#include<stdio.h>
#include<string.h>

char *strcspn_s(char * str1, char * str2 )
 {
    char *p1 = (char *)str1;
    char *p2;
    while (*p1 != '\0')
	 {
        p2 = (char *)str2;
        while (*p2 != '\0')
		 {
            if (*p2 == *p1)
			{
			 return p1-str1;
			}
            ++p2;
        }
        ++p1;
    }
    return  p1 - str1;
}

int main ()
{
    char str[] = "fcba73";
    char keys[] = "1234567890";
    int i;
    i = strcspn_s(str,keys);
    printf ("这个字符在第%d的位置\n",i+1);
    return 0;
}

9. 其他函数

如果参数符合下列条件返回真

iscntrl:任何控制字符
isspace:空白字符:空格‘ ’,换页‘\f’,换行'\n',回车‘\r’,制表符'\t'或者垂直制表符'\v'
isdigit:十进制数字 0~9
isxdigit:十六进制数字,包括所有十进制数字,小写字母af,大写字母AF
islower:小写字母a~z
isupper:大写字母A~Z
isalpha:字母az或AZ
isalnum:字母或者数字,az,AZ,0~9
ispunct:标点符号,任何不属于数字或者字母的图形字符(可打印)
isgraph:任何图形字符
isprint:任何可打印字符,包括图形字符和空白字符
toupper:将字符串中的字符转换成大写 
tolower:将字符串中的字符转换成小写
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixiaxiao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值