模拟实现字符串函数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 分钟前
整数拆分——动态规划
开发语言·数据结构·python·算法·leetcode·动态规划
叫我:松哥4 分钟前
基于数据挖掘的旅游景点个性化推荐系统设计与实现,Apriori和FP-Growth算法挖掘景点之间的关联规则
人工智能·python·算法·数据挖掘·数据分析·beautifulsoup
KaMeidebaby7 分钟前
卡梅德生物技术快报|噬菌体筛选:技术实操:宽谱大肠杆菌噬菌体筛选全流程与性能验证方案
前端·人工智能·算法·数据挖掘·数据分析
Hillain11 分钟前
软件设计师设计模式
java·开发语言·经验分享·笔记·算法·设计模式·软考
战族狼魂11 分钟前
AI 量化交易完整学习路线(从零到实战)
人工智能·算法·chatgpt·大语言模型·ai提示词·ai工程化
Frostnova丶9 小时前
【算法笔记】数学知识
笔记·算法
吴可可1239 小时前
AutoCAD 2016与2014二次开发关键差异
算法
雨白10 小时前
哈希:以时间换空间的算法实战
算法
San813_LDD12 小时前
[数据结构]LeetCode学习
数据结构·算法·图论