news 2026/5/12 3:51:27

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Day28~实现strlen、strcpy、strncpy、strcat、strncat

实现strlen、strcpy、strncpy、strcat、strncat

#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; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/9 12:04:51

技术工具类文章仿写专家Prompt指南

技术工具类文章仿写专家Prompt指南 【免费下载链接】LeagueAkari ✨兴趣使然的&#xff0c;功能全面的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/LeagueAkari 一、核心任务定义 你是一名专业的文章仿…

作者头像 李华
网站建设 2026/5/1 0:16:34

终极指南:5步实现B站视频高效批量下载与高清保存

终极指南&#xff1a;5步实现B站视频高效批量下载与高清保存 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等&#xff09…

作者头像 李华
网站建设 2026/5/5 17:24:20

2024年8月中文大模型战力榜:国产模型全面崛起改写全球竞争格局

一、行业背景与研究意义 【免费下载链接】DeepSeek-V2-Chat-0628 DeepSeek-V2-Chat-0628&#xff0c;开源创新之作&#xff0c;AI聊天机器人性能卓越&#xff0c;编码能力出众。在LMSYS Chatbot Arena榜单脱颖而出&#xff0c;多项任务表现领先。升级优化&#xff0c;体验更佳&…

作者头像 李华
网站建设 2026/5/8 10:17:54

LeetCode热题100--215. 数组中的第K个最大元素--中等

题目 给定整数数组 nums 和整数 k&#xff0c;请返回数组中第 k 个最大的元素。 请注意&#xff0c;你需要找的是数组排序后的第 k 个最大的元素&#xff0c;而不是第 k 个不同的元素。 你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。 示例 1: 输入: [3,2,1,5,6,4]…

作者头像 李华
网站建设 2026/5/6 7:28:24

C语言递归函数的习题笔记

字符串逆序的递归实现&#xff08;C语言&#xff09;在C语言中&#xff0c;实现字符串逆序的递归方法是一种高效且直观的方式。递归的核心思想是将问题分解为更小的子问题&#xff1a;通过交换字符串的首尾字符&#xff0c;然后递归地处理剩余的子字符串&#xff0c;直到整个字…

作者头像 李华
网站建设 2026/5/10 12:13:20

Flutter 通用弹窗组件 CustomDialogWidget:全自定义布局 + 多场景适配

在 Flutter 开发中&#xff0c;弹窗是交互反馈、信息确认、选项选择的核心载体。原生 showDialog 存在样式固化、布局灵活度低、多按钮适配差等问题&#xff0c;重复开发易导致 APP 内弹窗风格混乱。本文封装的 CustomDialogWidget 整合 “头部 内容 按钮区” 全自定义、单选…

作者头像 李华