模拟实现字符串函数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;
}
相关推荐
Coovally AI模型快速验证1 小时前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·yolo·计算机视觉·transformer·无人机
pusue_the_sun1 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
RaymondZhao342 小时前
【全面推导】策略梯度算法:公式、偏差方差与进化
人工智能·深度学习·算法·机器学习·chatgpt
zhangfeng11332 小时前
DBSCAN算法详解和参数优化,基于密度的空间聚类算法,特别擅长处理不规则形状的聚类和噪声数据
算法·机器学习·聚类
啊阿狸不会拉杆3 小时前
《算法导论》第 32 章 - 字符串匹配
开发语言·c++·算法
小学生的信奥之路3 小时前
洛谷P3817题解:贪心算法解决糖果分配问题
c++·算法·贪心算法
你知道网上冲浪吗4 小时前
【原创理论】Stochastic Coupled Dyadic System (SCDS):一个用于两性关系动力学建模的随机耦合系统框架
python·算法·数学建模·数值分析
地平线开发者5 小时前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy6 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
CoovallyAIHub6 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉