当前位置: 编程技术>c/c++/嵌入式
探讨编写int strlen(char *strDest);不允许定义变量的问题
来源: 互联网 发布时间:2014-10-16
本文导语: 在论坛上看到一位前辈当年的面试题,原话是这样说的“有一次在面试时遇到这样一个问题:不允许调用库函数,也不允许使用任何全局或局部变量编写 int strlen(char *strDest); ”,无意中看到,自己想了一会儿,没有思路,后...
在论坛上看到一位前辈当年的面试题,原话是这样说的“有一次在面试时遇到这样一个问题:不允许调用库函数,也不允许使用任何全局或局部变量编写 int strlen(char *strDest); ”,无意中看到,自己想了一会儿,没有思路,后来整理了各位牛人的回复,觉得采用递归方法解决这个问题,是一种挺好的办法!于是,稍微写了一下代码,算是开拓视野的一点点积累吧!
#include "stdafx.h"
#include
#include //使用断言assert的头文件
using namespace std;
//普通的方法
int MyStrlen(const char* strDest)
{
assert(NULL != strDest); //使用了断言,如果strDest为Null,则终止程序
int i(0);
while ('' != *strDest)//判断字符串结束的标志,''标识符
{
i ++;
strDest ++;
}
return i;
}
//采用递归方式,没有定义新的全局变量和局部变量
int MyStrlen2(const char* strDest)
{
assert(NULL != strDest);//使用了断言,如果strDest为Null,则终止程序
if ('' != *strDest)
{
return 1 + MyStrlen2(++strDest);
}
else
{
return 0;
}
}
//和上面的方法类似,只不过采用的问号表达式
int MyStrlen3(const char* strDest)
{
assert(NULL != strDest);//使用了断言,如果strDest为Null,则终止程序
return ('' != *strDest) ? (1 + MyStrlen3((++strDest))) : 0; //这时候i++和++i的区别价值体现出来了,strDest++不行,考虑一下为何?
}
int _tmain(int argc, _TCHAR* argv[])
{
char a[] = {"Hello World!"};
cout
代码如下:
#include "stdafx.h"
#include
#include //使用断言assert的头文件
using namespace std;
//普通的方法
int MyStrlen(const char* strDest)
{
assert(NULL != strDest); //使用了断言,如果strDest为Null,则终止程序
int i(0);
while ('' != *strDest)//判断字符串结束的标志,''标识符
{
i ++;
strDest ++;
}
return i;
}
//采用递归方式,没有定义新的全局变量和局部变量
int MyStrlen2(const char* strDest)
{
assert(NULL != strDest);//使用了断言,如果strDest为Null,则终止程序
if ('' != *strDest)
{
return 1 + MyStrlen2(++strDest);
}
else
{
return 0;
}
}
//和上面的方法类似,只不过采用的问号表达式
int MyStrlen3(const char* strDest)
{
assert(NULL != strDest);//使用了断言,如果strDest为Null,则终止程序
return ('' != *strDest) ? (1 + MyStrlen3((++strDest))) : 0; //这时候i++和++i的区别价值体现出来了,strDest++不行,考虑一下为何?
}
int _tmain(int argc, _TCHAR* argv[])
{
char a[] = {"Hello World!"};
cout