模拟实现字符串函数1(详细版本)

求字符串长度--strlen

基本实现和注意事项

#include<stdio.h>
#include<string.h>
int main()
{
  printf("%d",strlen("abcdefgeh"));
}
  • strlen函数计算字符串长度是找到'\0'为止,所以当我们以数组字符的形式创建字符串时千万不要忘记在最后加上字符串结束标志--'\0'
  • strlen函数在库函数中,所以不要忘记引头文件
  • size_t strlen(const char* str) 由这个可以得出strlen函数的返回类型是无符号整形,所以当比较两个字符串长短时应注意

模拟实现strlen函数

法一:计数器法
#include<stdio.h>
#include<assert.h>
int my_strlen(char* str)
{
   assert(str);
   int count=0;
   while(*str)
   {
      count++;
      str++;
   }
   return count;
}
int main()
{
   char arr[]="abcdef";
   int len=my_strlen(arr);
   printf("%d",len);
   return 0;
}
法二:递归(不创建临时变量)
#include<stdio.h>
#include<assert.h>
int my_strlen(char* str)
{
  assert(str);
  if(*str)
  {
    return (1+(my_strlen(str+1)));
  }
  else
  {
    return 0;
  }
}
int main()
{
  char arr[]="abcdef";
  int len=my_strlen(arr);
  printf("%d",len);
  return 0;
}

字符串拷贝函数--strcpy

基本实现和注意事项

#include<stdio.h>
#include<string.h>
int main()
{
  char arr1[]="abefd";
  char arr2[]="ljsj";
  strcpy(arr1,arr2);
  printf("%s",arr1);
  return 0;
}
  • char* strcpy(char* dest,const char* src),指针dest是指要被改变的字符串,src指的是要改变成为的字符串,src不会被改变,所以加const保护修饰
  • 注意当使用字符串拷贝函数时,dest所指的空间应该大于src所指的空间,避免出现栈溢出的情况

模拟实现strcpy函数

#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* str1,const char* str2)
{
  assert(str1&&str2);
  char* ret=str1;
  while(*str2!='\0')
  {
    *str1=*str2;
    str1++;
    str2++;
  }
  *str1=*str2;
  return ret;
}
int main()
{
  char arr1[]="abcefdf";
  char arr2[]="ljih";
  my_strcpy(arr1,arr2);
  printf("%s",arr1);
  return 0;
}

字符串追加--strcat

基本时间和注意事项

#include<stdio.h>
#include<string.h>
int main()
{
  char arr1[50]="hello";
  char arr2[]="world";
  strcat(arr1,arr2);
  printf("%s",arr1);
  return 0;
}
  • char* strcat(char* des,const char* src) 和strcpy相似,在使用时应确保目的指针所指向的空间足够大。
  • 别忘引头文件

模拟实现strcat

#include<stdio.h>
char* my_strcpy(char* str1,const char* str2)
{
  assert(str1&&str2);
  char* ret=str1;
  while(*str1!='\0')
  {
    str1++;
  }
  while(*str2!='\0')
  {
    *str1=*str2;
    str2++;
    str1++;
  }
  *str1=*str2;
  return ret;
}
int main()
{
  int arr1[25]="hello";
  int arr2[]="world";
  my_strcat(arr1,arr2);
  printf("%s",arr1);
  return 0;
}

字符串比较--strcmp

基本实现和注意事项

#include<stdio.h>
#include<string.h>
int main()
{
  char arr1[]="abc";
  char arr2[]="abd";
  int ret=strcmp(arr1,arr2);
  printf("%d",ret);
  return 0;
}
  • int strcmp(const char* str1,const char* str2);比较字符串不会改变字符串,所以都加上const修饰保护。
  • 当str1>str2时,函数会返回一个大于0的数字;当str1<str2时,函数会返回一个小于0的数字;当两个字符串相等会返回0
  • 不同的编译器返回的数字不同

模拟实现strcmp

#include<stdio.h>
#include<assert.h>
int my_strcmp(const char* str1,const char* str2)
{
  assert(str1&&str2);
  while(*str1==*str2)
  {
    if(*str1=='\0'||*str2=='\0')
    {
      return 0;
    }
    str1++;
    str2++;
  }
  if(*str1>*str2)
  {
    return 1;
  }
  else if(*str1<*str2)
  {
    return -1;
  }
}
int main()
{
  char arr1[]="abcdfe";
  char arr2[]="abcefsa";
  int ret=my_strcmp(arr1,arr2);
  return 0;
}
相关推荐
pianmian16 分钟前
完全平方数
数据结构·算法
A_Tai23333338 分钟前
贪心算法解决用最少数量的箭引爆气球问题
算法·贪心算法
唐叔在学习20 分钟前
【唐叔学算法】第19天:交换排序-冒泡排序与快速排序的深度解析及Java实现
java·算法·排序算法
_nirvana_w_20 分钟前
C语言实现常用排序算法
c语言·算法·排序算法
唐叔在学习27 分钟前
【唐叔学算法】第18天:解密选择排序的双重魅力-直接选择排序与堆排序的Java实现及性能剖析
数据结构·算法·排序算法
Kenneth風车1 小时前
【机器学习(九)】分类和回归任务-多层感知机(Multilayer Perceptron,MLP)算法-Sentosa_DSML社区版 (1)11
算法·机器学习·分类
最后一个bug1 小时前
rt-linux中使用mlockall与free的差异
linux·c语言·arm开发·单片机·嵌入式硬件·算法
蹉跎x2 小时前
力扣1358. 包含所有三种字符的子字符串数目
数据结构·算法·leetcode·职场和发展
rainoway2 小时前
CRDT宝典 - yata算法
前端·分布式·算法
巫师不要去魔法部乱说3 小时前
PyCharm专项训练4 最小生成树算法
算法·pycharm