模拟实现字符串函数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;
}
相关推荐
加藤不太惠5 分钟前
十大排序其六
算法·排序算法
前端小刘哥11 分钟前
视频推拉流平台EasyDSS技术特点及多元应用场景剖析
算法
Brianna Home14 分钟前
从零到一:用Godot打造2D游戏《丛林探险》
算法·游戏·性能优化·游戏引擎·bug·godot·动画
小欣加油15 分钟前
leetcode 143 重排链表
数据结构·c++·算法·leetcode·链表
courniche1 小时前
ECDH、ECDHE、ECDLP、ECDSA傻傻分不清?
算法·密码学
前端小刘哥1 小时前
超低延迟与高并发:视频直播点播平台EasyDSS在游戏直播场景的技术实践
算法
毅炼1 小时前
常见排序算法
java·算法·排序算法
猫梦www1 小时前
力扣21:合并两个有序链表
数据结构·算法·leetcode·链表·golang·力扣
Han.miracle2 小时前
数据结构——排序的学习(一)
java·数据结构·学习·算法·排序算法
爱coding的橙子2 小时前
每日算法刷题Day76:10.19:leetcode 二叉树12道题,用时3h
算法·leetcode·职场和发展