探讨编写int strlen(char *strDest);不允许定义变量的问题

所属分类: 软件编程 / C 语言 阅读数: 109
收藏 0 赞 0 分享
在论坛上看到一位前辈当年的面试题,原话是这样说的“有一次在面试时遇到这样一个问题:不允许调用库函数,也不允许使用任何全局或局部变量编写 int strlen(char *strDest);  ”,无意中看到,自己想了一会儿,没有思路,后来整理了各位牛人的回复,觉得采用递归方法解决这个问题,是一种挺好的办法!于是,稍微写了一下代码,算是开拓视野的一点点积累吧!
复制代码 代码如下:

#include "stdafx.h"
#include <iostream>
#include<assert.h>  //使用断言assert的头文件
using namespace std;
//普通的方法
int MyStrlen(const char* strDest)
{
 assert(NULL != strDest); //使用了断言,如果strDest为Null,则终止程序
 int i(0);
 while ('\0' != *strDest)//判断字符串结束的标志,'\0'标识符
 {
  i ++;
  strDest ++;
 }
 return i;
}
//采用递归方式,没有定义新的全局变量和局部变量
int MyStrlen2(const char* strDest)
{
 assert(NULL != strDest);//使用了断言,如果strDest为Null,则终止程序
 if ('\0' != *strDest)
 {
  return 1 + MyStrlen2(++strDest);
 }
 else
 {
  return 0;
 }
}
//和上面的方法类似,只不过采用的问号表达式
int MyStrlen3(const char* strDest)
{
 assert(NULL != strDest);//使用了断言,如果strDest为Null,则终止程序
 return ('\0' != *strDest) ? (1 + MyStrlen3((++strDest))) : 0;  //这时候i++和++i的区别价值体现出来了,strDest++不行,考虑一下为何?
}
int _tmain(int argc, _TCHAR* argv[])
{
 char a[] = {"Hello World!"};
 cout << MyStrlen(a) << endl;
 cout << MyStrlen2(a) << endl;
 cout << MyStrlen3(a) << endl;
 return 0;
}

注意 :++strDest不能换成strDest++,  这时候i++和++i的区别价值体现出来了,strDest++不行,考虑一下为何?
更多精彩内容其他人还在看

从汇编看c++中变量类型的深入分析

本篇文章是对c++中的变量类型进行了详细的分析介绍。需要的朋友参考下
收藏 0 赞 0 分享

从汇编看c++的默认析构函数的使用详解

本篇文章是对c++中默认析构函数的使用进行了详细的分析介绍。需要的朋友参考下
收藏 0 赞 0 分享

基于c++中的默认拷贝函数的使用详解

本篇文章对c++中默认拷贝函数的使用进行了详细的分析介绍。需要的朋友参考下
收藏 0 赞 0 分享

解析c++中的默认operator=操作的详解

本篇文章是对c++中的默认operator=操作的应用进行了详细的分析介绍。需要的朋友参考下
收藏 0 赞 0 分享

解析c++中参数对象与局部对象的析构顺序的详解

本篇文章是对c++中参数对象与局部对象的析构顺序进行了详细的分析介绍,需要的朋友参考下
收藏 0 赞 0 分享

深入c++中临时对象的析构时机的详解

本篇文章对c++中临时对象的析构时机进行了详细的分析介绍,需要的朋友参考下
收藏 0 赞 0 分享

解析内存对齐 Data alignment: Straighten up and fly right的详解

对于所有直接操作内存的程序员来说,数据对齐都是很重要的问题.数据对齐对你的程序的表现甚至能否正常运行都会产生影响
收藏 0 赞 0 分享

深入内存对齐的详解

本篇文章是对内存对齐进行了详细的分析介绍,需要的朋友参考下
收藏 0 赞 0 分享

深入C语言把文件读入字符串以及将字符串写入文件的解决方法

本篇文章是对C语言把文件读入字符串以及将字符串写入文件的方法进行了详细的分析介绍,需要的朋友参考下
收藏 0 赞 0 分享

深入Windows下的回车是回车换行(\r\n)还是换行回车(\n\r)的详解

本篇文章对Windows下的回车是回车换行(\r\n)还是换行回车(\n\r)进行了详细的分析介绍,需要的朋友参考下
收藏 0 赞 0 分享
查看更多