求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)
class Solution {
public:
class Sum //定义一个Sum的内部类
{
public:
Sum()//构造函数
{
sum += i;
i++;
}
};
int Sum_Solution(int n) {
i = 1;//测试用例不止一个,所以每次调用时要把i和sum置为初始值
sum = 0;
Sum array[n];//定义一个由n个大小的数组,数组就有n个对象,每个对象被定义时都要调用它的构造函数,有n个对象就要调用构造函数n次
return sum;
}
private:
static int i;//把i和sum用static修饰成静态变量,以使每个对象访问的都是同一个,便于多个对象共享
static int sum;
};
int Solution::sum = 0;
int Solution:: i = 1;