当前位置: 首页 > news >正文

函数的模拟实现

题一:

模拟实现strncpy 

#include <stdio.h>void my_strncpy(char* arr2, char* arr1, size_t num){int i = 0;for (i = 0; i < num; i++){*(arr2 + i) = *(arr1 + i);}}int main(){char arr1[] = "hello liangzai";char arr2[10] = { 0 };//strncpy(arr2,arr1,sizeof(arr2));my_strncpy(arr2, arr1, sizeof(arr2));return 0;}

优解一:

char * mystrncpy(char * dst, const char * src, size_t n)
{int i;for (i = 0; src[i] && i < n; i++){dst[i] = src[i];}if (i < n){dst[i] = 0;}return dst;
}

题二:

模拟实现strncat

#include <stdio.h>#include <string.h>char* my_strncat(char* arr1, const char* arr2, size_t num){int sz = strlen(arr1);int i = 0;for (i = 0; i < num; i++){*(arr1 + sz + i) = *(arr2 + i);}return arr1;}int main(){char arr2[] = "shawanyi ";char arr1[20] = "hello ";//strncat(arr1,arr2,10);my_strncat(arr1, arr2, 10);return 0;}

优解一:

char * mystrncat(char * dst, const char * src, size_t n)
{char * tmp = dst;while (*dst){dst++;//记录到dst最后一个位置}int i;for (i = 0; src[i] && i < n; i++){dst[i] = src[i];}dst[i] = 0;return tmp;
}

题三:

模拟实现atoi

#include <stdio.h>#include <stdlib.h>#include <assert.h>#include <ctype.h>int my_atoi(const char* arr1){assert(arr1);int sum = 0;if (*(arr1) == '\0'){return 0;}while(isspace(*arr1)){arr1++;}int flat = 1;if (*arr1 == '+'){arr1++;}else if (*arr1 == '-'){flat = -1;arr1++;}int ret = 0;while (isdigit(*arr1)){ret = ret * 10 + (*arr1 - '0');if (ret > INT_MAX){return INT_MAX * flat;}else if (ret < INT_MIN){return INT_MIN * flat;}arr1++;}if (isdigit(*arr1) == 0){return ret * flat;}return ret*flat;}int main(){char arr1[] = "-123666a44";//int n = atoi(arr1);int sz = 0;sz = my_atoi(arr1);return 0;}

优解一

#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
//VALID 表示结果合法
//INVALID 表示结果非法
enum State
{VALID,//0INVALID//1
};
//默认结果可能非法,当正确转换后再改为合法
enum State state = INVALID;
​
int my_atoi(char *str)
{int flag = 1;long long ret = 0;assert(str);state = INVALID;//跳过空白字符while(isspace(*str)){str++;}if(*str == '\0'){return 0;}//跳过正负号if(*str == '+'){str++;}else if(*str == '-'){flag = -1;str++;}//开始转换数字字符直到非数字字符while(isdigit(*str)){ret = ret * 10 + flag * (*str-'0');if((ret > INT_MAX) || (ret < INT_MIN)){return 0;}str++;}//正常停止if(*str == '\0'){state = VALID;return (int)ret;}else{//遇到非数字字符return (int)ret;}

http://www.lryc.cn/news/120944.html

相关文章:

  • CSDN博客批量查询质量分https://yma16.inscode.cc/请求超时问题(设置postman超时时间)(接口提供者设置了nginx超时时间)
  • 什么是 CSRF 攻击?
  • [内网渗透]CFS三层靶机渗透
  • 一百五十一、Kettle——Linux上安装的kettle8.2开启carte服务以及配置子服务器
  • 2023高教社杯数学建模A题 B题C题 D题 E题思路代码分析
  • 从ChatGLM2-6B来看大模型扩展上下文和加速推理相关技术
  • Unity特效总览
  • Unity中人物控制器
  • 零钱兑换-输出组合数
  • Mybatis 小结
  • 【Cartopy】库的安装和瓦片加载(天地图、高德等)
  • TCPDF生成PDF文件,含jpjraph生成雷达图
  • Flink-串讲面试题
  • 如何培养对技术的热爱
  • Vue响应式数据的原理
  • pytest fixture 用于teardown工作
  • 39 printf 的输出到设备层的调试
  • 数字普惠金融、数字创新与经济增长—基于省级面板数据的实证考察(2011-2021年)
  • 控制renderQueue解决NGUI与Unity3D物体渲染顺序问题
  • 概率论与数理统计:第二、三章:一维~n维随机变量及其分布
  • BOLT- 识别和优化热门的基本块
  • Golang 中的 time 包详解(四):函数详解
  • 【前端 | CSS】5种经典布局
  • 腾讯云宣布VPC网络架构重磅升级,可毫秒级感知网络故障并实现自愈
  • vue 路由页面跳转
  • Vue toRefs:在Vue中不失去响应式的情况下解构属性
  • 自定义element-plus的弹框样式
  • Linux:iptables防火墙
  • MongoDB文档-进阶使用-spring-boot整合使用MongoDB---MongoTemplate完成增删改查
  • 设计模式十四:责任链模式(Chain of Responsibility Pattern)