C语言面试高频问题:自己代码实现字符串相关的常用API

参考:C语言面试高频问题:自己代码实现字符串相关的常用API
作者:图触靓
发布时间: 2020-08-08 13:31:33
网址:https://blog.csdn.net/bhbhhyg/article/details/107878102

目录

      • 1、实现get(char *);从键盘获取字符串
      • 2、实现put(char *);输出字符串
      • 3、实现strlen(char *);求字符串长度
      • 4、实现strcpy(char *,char *);拷贝str2的内容到str1;
      • 5、实现strcat(char *,char *);合并字符串,把str2的内容合并到str1的后面
      • 6、实现strcmp(char *,char*)比较字符串大小,若两字符串内容完全相同,返回0,若str1比str2长返回1,str1比str2短则返回-1,长度相同内容不同也返回-1

1、实现get(char *);从键盘获取字符串

void myget(char *str)
{	while(1){	scanf("%c",str);if(*str=='\n'){	*str='\0';return;}str++;} 
}

2、实现put(char *);输出字符串

void myput(char *str)
{while(*str!='\0'){printf("%c",*str++);}printf("\n");return;
}

3、实现strlen(char *);求字符串长度

int mystrlen(char *str)
{	int len=0;while(1){if(*str=='\0'){return len;}str++;len++;}}

4、实现strcpy(char *,char *);拷贝str2的内容到str1;

void mystrcpy(char * str1,char * str2)
{while(*str2!='\0'){*str1=*str2;str1++;str2++;}
}

5、实现strcat(char *,char *);合并字符串,把str2的内容合并到str1的后面

void mystrcat(char *str1,char *str2)
{while(*str1!='\0'){str1++;}while(*str2!='\0'){*str1=*str2;str2++;str1++;}return;} 

6、实现strcmp(char ,char)比较字符串大小,若两字符串内容完全相同,返回0,若str1比str2长返回1,str1比str2短则返回-1,长度相同内容不同也返回-1

int mystrcmp(char *str1,char *str2)
{	int str1len=0;int str2len=0;while(*str1!='\0') {str1++;str1len++;}while(*str2!='\0') {str2++;str2len++;}if(str1len-str2len==0){for(int i=0;i<str1len;i++){if(*str1==*str2){str1--;str2--;}else{return -1;}}return 0;}else if(str1len-str2len>0){return 1;}else {return -1;}
} 

以上仅是个人思路,并非算法最优

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/265560.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python时间复杂度计算题答案

评论 题目链接 https://blog.csdn.net/qq_33254766/article/details/132255078 答案 时间复杂度&#xff1a;O(n)。 分析&#xff1a;这段代码遍历了n次&#xff0c;所以时间复杂度是线性的&#xff0c;即O(n)。 时间复杂度&#xff1a;O(n^2)。 分析&#xff1a;两个嵌套的…

【性能优化】优化笔记之一:图像RGB与YUV转换优化

本文主要介绍如何优化您自己的CODE&#xff0c;实现软件的加速。我们一个图象模式识别的项目&#xff0c;需要将RGB格式的彩色图像先转换成黑白图像。图像转换的公式如下&#xff1a; Y 0.299 * R 0.587 * G 0.114 * B 图像尺寸640*480*24bit&#xff0c;RGB图像已经按照RGB…

wxpython使用方法_python图形界面开发之wxPython树控件使用方法详解

wxPython树控件介绍树(tree)是一种通过层次结构展示信息的控件&#xff0c;如下图所示是树控件示例&#xff0c;左窗口中是树控件&#xff0c;在wxPython中树控件类是wx.TreeCtrl。wx.TreeCtrl常用的方法有AddRoot(text, image-1, selImage-1, dataNone)。添加根节点&#xff0…

DSP_SCI

F2833x Serial Communication Interface 簡介 串行通信接口&#xff08;SCI&#xff09;模塊是一個串行I / O端口&#xff0c;允許F2833x與其他外圍設備之間的異步通信。 它通常被稱為UART&#xff08;通用異步接收器發送器&#xff09;&#xff0c;通常根據RS232標準使用。 SC…

如何让自己的写的程序在阿里云一直运行

参考&#xff1a;如何让自己的写的程序在阿里云一直运行 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-08-02 11:53:28 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107742311 目录1、下载screen&#xff1a;2、运行screen&#xff0c;创建一个scree…

C程序设计语言--第五章:指针与数组

为什么80%的码农都做不了架构师&#xff1f;>>> 指针是一种保存变量地址的变量. 5.1 指针与地址 通常的机器都有一系列连续编号或编址的存储单元,这些存储单元可以单个进行操纵,也可以连续成组的方式操纵.指针是能够存放一个地址的一组存储单元(通常是两个或四个…

java list 自定义类型转换_使用Java Stream API将List按自定义分组规则转换成Map的一个例子...

本文完整测试代码见文末。测试数据是List里的4个员工对象实例&#xff1a;根据员工所在的城市进行分组&#xff1a;结果分成了三组&#xff1a;第一组的员工在上海&#xff1a;第二组的员工在成都&#xff1a;统计每组员工个数&#xff1a;把员工进行分组&#xff0c;得分大于1…

安卓app与阿里云服务器的无线通信(非局域网)

参考&#xff1a;安卓app与阿里云服务器的无线通信&#xff08;非局域网&#xff09; 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-08-01 16:13:14 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107732156 目录写在阿里云里面的服务器代码&#xff1…

10.继承和派生

2019独角兽企业重金招聘Python工程师标准>>> 类成员访问权限&#xff1a; 成员访问权限&#xff1a;私有成员&#xff1a;只能被类自身的成员和友元访问&#xff1b; 公有成员&#xff1a;可以被任何普通函数和任何类的成员函数或子类访问&#xff1b; 保护成员&a…

1185 威佐夫游戏 V2

1185 威佐夫游戏 V2 有2堆石子。A B两个人轮流拿&#xff0c;A先拿。每次可以从一堆中取任意个或从2堆中取相同数量的石子&#xff0c;但不可不取。拿到最后1颗石子的人获胜。假设A B都非常聪明&#xff0c;拿石子的过程中不会出现失误。给出2堆石子的数量&#xff0c;问最后谁…

java date 判断是否是今天_java——推断日期是否在今天之前

这里说的日期是指字符串的日期格式&#xff0c;如“2014-10-15”&#xff0c;我们要推断这个日期是否在今天之前&#xff0c;网上看到好多推断的方法&#xff0c;都是拿这个日期转换成Date对象 然后与new Date()比較&#xff0c;使用comparetTo() 或者before()方法&#xff0c…

树莓派与阿里云服务器之间的无线通信(非局域网)

参考&#xff1a;Linux虚拟机sqlite数据库安装教程 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-08-01 15:45:026 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107731166 购买服务器后。我们可以点击控制台&#xff0c;找到实例列表&#xff0c;点击…

IOS开发博客学习

M了个J :http://www.cnblogs.com/mjios/tag/objective-c/ http://www.cnblogs.com/tianjian/p/3358602.html Cocos2d-x VS环境配置 泰然论坛&#xff1a;http://www.ityran.com/archives/category/cocos2d-iphone 1.http://www.cnblogs.com/zilongshanren/archive/2011/09/19…

CLR via C#学习笔记-第十三章-定义接口、继承接口

13.1 类和接口继承 接口是为了实现多继承 所有的类都继承了System.Object&#xff0c;及其四个公共实例方法&#xff1a;ToString、Equals、GetHashCode、GetType。 CLR允许定义接口&#xff0c;它实际只是对一组方法签名进行了统一命名。这些方法不提供任何实现。 类通过指定接…

树莓派与安卓手机app的WIFI通信(局域网通信)

参考&#xff1a;树莓派与安卓手机app的WIFI通信&#xff08;局域网通信&#xff09; 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-07-29 10:18:12 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107655967 目录树莓派作为服务器安卓端连接服务器的方…

C语言递归练习

1、炮弹一样的球状物体&#xff0c;能够堆积成一个金字塔&#xff0c;在顶端有一个炮弹&#xff0c;它坐落在一个4个炮弹组成的层面上&#xff0c;而这4个炮弹又坐落在一个9个炮弹组成的层面上&#xff0c;以此类推。写一个递归函数CannonBall&#xff0c;这个函数把金字塔的高…

业余剪辑——从拍摄到剪辑到加字幕

工作需要帮公司做一个公司的宣传片&#xff0c;要求不是很高所以就让我这个半吊子“设计”来做视频了。。。 以下设备和软件的使用只是我个人本次的使用的记录&#xff0c;大家按需使用即可 一、拍摄 设备&#xff1a;手机 软件&#xff1a;剪辑大师app&#xff08;应用商店下载…

java mp3 to wav_java实现wavToMP3格式转换详解

这里需要用到一个jar包:jave-1.0.1.jar,下载地址的话自己百度吧.废话不多说直接贴代码&#xff1a;import it.sauronsoftware.jave.AudioAttributes;import it.sauronsoftware.jave.Encoder;import it.sauronsoftware.jave.EncodingAttributes;import java.io.File;public clas…

树莓派作为客户端与WemosD1作为服务器的无线通信(局域网通信)

参考&#xff1a;树莓派作为客户端与WemosD1作为服务器的无线通信&#xff08;局域网通信&#xff09; 作者&#xff1a;图触靓 发布时间&#xff1a; 2020-07-26 21:50:39 网址&#xff1a;https://blog.csdn.net/bhbhhyg/article/details/107599915 目录wemos版作为服务端代码…