题目:求1+2+...+n,要求不能使用乘除法、for、while、if、else、swithc、case等关键字及条件判断语句(A?B:C)。
解法一:利用构造函数求解
1 class Temp 2 { 3 public: 4 Temp() 5 { 6 ++N; 7 Sum+=N; 8 } 9 static void Reset()10 {11 N = 0;12 Sum = 0;13 }14 static unsigned int GetSum()15 {16 return sum;17 }18 private:19 static unsigned int N;20 static unsigned int Sum;21 }22 unsigned int Temp::N = 0;23 unsigned int Temp::Sum = 0;24 25 unsiged int Sum_Solution1(unsigned int n)26 {27 Temp::Reset();28 Temp* a = new Temp[n];29 delete [] a;30 a = NULL;31 return Temp::GetSum();32 }
解法二:利用虚函数求解
可以定义两个函数,一个函数充当递归函数的角色,另一个函数处理终止递归的情况,我们需要做的就是在两个函数里二选一。从二选一我们很自然地想到布尔变量。现在的问题是如何把数值变量n转换成布尔值。如果对n连续做两次反运算,即!!n,那么非零的n转换为true,0转换为false。
1 class A; 2 A* Array[2]; 3 4 class A 5 { 6 public: 7 virtual unsigned int Sum(unsigned int n) 8 { 9 return 0;10 }11 };12 13 class B: publice A14 {15 public:16 virtual unsigned int Sum(unsigned int n)17 {18 return Array[!!n]->Sum(n-1)+n;19 }20 };21 22 int Sum_Solution2(int n)23 {24 A a;25 B b;26 Array[0] = &a;27 Array[1] = &b;28 return Array[1]->Sum(n);29 }
解法三:利用函数指针求解
在纯C语言的编程环境中,我们不能使用虚函数,此时可以用函数指针来模拟。
1 typedef unsigned int (*fun)(unsigned int); 2 unsigned int Solution3_Teminator(unsigned int n) 3 { 4 return 0; 5 } 6 7 unsigned int Sum_Solution3(unsigned int n) 8 { 9 static fun f[2] = {Solution3_Teminator, Sum_Solution3};10 return n+f[!!n](n-1);11 }
解法四:利用模板类型求解
见《剑指Offer》。