Day28~实现strlen、strcpy、strncpy、strcat、strncat

实现strlen、strcpy、strncpy、strcat、strncat

cpp 复制代码
#include <stdio.h>

size_t my_strlen(const char *src)
{
    size_t len = 0;

    while (*src != '\0')
    {
        len++;
        src++;
    }
    return len;
}

char *my_strcpy(char *dest, const char *src)
{
    if (dest == NULL || src == NULL) // 判断输入的字符是否为空
    {
        return NULL; // 如果为空,就返回空
    }

    char *temp = dest; // 将dest的地址赋值给一个临时变量

    while (*src != '\0') // 遍历要拷贝的字符
    {
        *temp = *src; // 将src的值赋给temp
        src++;        // src地址后移
        temp++;       // temp地址后移
    }

    *temp = '\0'; // 最后一位为\0
 
    return dest; // 返回dest
}

char *my_strncpy(char *dest, const char *src, size_t n)
{
    if (dest == NULL || src == NULL)
    {
        return NULL;
    }

    char *temp = dest;

    size_t i;

    for (i = 0; (i < n) && (*src != '\0'); i++)
    {
        *temp = *src;
        src++;
        temp++;
    }

    for (; i < n; i++)
    {
        *temp = '\0';
    }

    return dest;
}

char *my_strcat(char *dest, const char *src)
{
    if (dest == NULL || src == NULL)
    {
        return NULL;
    }

    char *temp = dest;

    while (*temp != '\0')
    {
        temp++;
    }

    while (*src != '\0')
    {
        *temp = *src;
        temp++;
        src++;
    }

    *temp = '\0';

    return dest;
}

char *my_strncat(char *dest, const char *src, size_t n)
{
    if (dest == NULL || src == NULL)
    {
        return NULL;
    }

    char *temp = dest;

    while (*temp != '\0')
    {
        temp++;
    }

    size_t i;

    for (i = 0; (i < n) && (*src != '\0'); i++)
    {
        *temp = *src;
        src++;
        temp++;
    }

    for (; i < n; i++)
    {
        *temp = '\0';
    }

    return dest;
}

int main()
{
    char dest[100] = "Hello World";
    char src[100] = "Hello World";

    // char *result1 = my_strcpy(dest, src);
    // char *result2 = my_strncpy(dest, src, 3);
    // size_t result = my_strlen(src);
    // char *result3 = my_strcat(dest, src);
    char *result4 = my_strncat(dest, src, 3);

    // printf("%s\n", result1);
    // printf("%s\n", result2);
    // printf("%ld\n", result);
    // printf("%s\n", result3);
    printf("%s\n", result4);

    return 0;
}
相关推荐
啊森要自信31 分钟前
CANN ops-cv:AI 硬件端视觉算法推理训练的算子性能调优与实战应用详解
人工智能·算法·cann
czy878747537 分钟前
深入了解 C++ 中的 `std::bind` 函数
开发语言·c++
我在人间贩卖青春1 小时前
C++之继承的方式
c++·private·public·protected·继承方式
仟濹1 小时前
算法打卡day2 (2026-02-07 周五) | 算法: DFS | 3_卡码网99_计数孤岛_DFS
算法·深度优先
驭渊的小故事1 小时前
简单模板笔记
数据结构·笔记·算法
YuTaoShao1 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头1 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa1 小时前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior1 小时前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
Σίσυφος19002 小时前
PCL法向量估计 之 RANSAC 平面估计法向量
算法·机器学习·平面