模拟实现字符串函数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;
}
相关推荐
朱剑君3 小时前
第四天——贪心算法——种花
算法·贪心算法
TextIn智能文档云平台3 小时前
PDF文档解析新突破:图表识别、公式还原、手写字体处理,让AI真正读懂复杂文档!
图像处理·人工智能·算法·自然语言处理·pdf·ocr
Panesle3 小时前
HunyuanCustom:文生视频框架论文速读
人工智能·算法·音视频·文生视频
hie988943 小时前
matlab稳定求解高精度二维对流扩散方程
算法·机器学习·matlab
买了一束花4 小时前
MATLAB导出和导入Excel文件表格数据并处理
人工智能·算法·matlab
纪元A梦4 小时前
贪心算法应用:顶点覆盖问题详解
java·算法·贪心算法
爱补鱼的猫猫5 小时前
22、近端策略优化算法(PPO)论文笔记
论文阅读·算法
开心星人5 小时前
【论文阅读】Reconstructive Neuron Pruning for Backdoor Defense
论文阅读·算法·剪枝
_Itachi__6 小时前
LeetCode 热题 100 543. 二叉树的直径
java·算法·leetcode
是代码侠呀7 小时前
飞蛾扑火算法matlab实现
开发语言·算法·matlab·github·github star·github 加星