程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C >> C語言基礎知識 >> 探討編寫int strlen(char *strDest);不允許定義變量的問題

探討編寫int strlen(char *strDest);不允許定義變量的問題

編輯:C語言基礎知識
在論壇上看到一位前輩當年的面試題,原話是這樣說的“有一次在面試時遇到這樣一個問題:不允許調用庫函數,也不允許使用任何全局或局部變量編寫 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++不行,考慮一下為何?
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved