在論壇上看到一位前輩當年的面試題,原話是這樣說的
“有一次在面試時遇到這樣一個問題:不允許調用庫函數,也不允許使用任何全局或局部變量編寫 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++不行,考慮一下為何?