原题链接:
求1+2+3+...+n_牛客题霸_牛客网 (nowcoder.com)
这道题目要求计算从1到n的整数和,但禁止使用一系列常见的编程构造和关键字,如乘除法、循环语句(for、while)、条件判断语句(if、else、switch、case)以及三元运算符(A?B:C)。
也就是排除了数学方法、循环相加法、递归方法
这是一个有趣的挑战,需要利用一些编程技巧来绕过这些限制。
Sum
,其中包含两个静态成员变量count
和ret
。count
用于记录已创建的Sum
对象数量,而ret
用于累加这些对象的序号(即每次创建Sum
对象时,其序号会被加到ret
上)。Sum
类的构造函数每次被调用时,都会将count
加1,并将count
的当前值加到ret
上。这样,通过创建n
个Sum
对象,ret
就会累加从1到n的所有整数。Solution
类中定义一个成员函数Sum_Solution
,该函数接受一个整数n
作为参数。Sum_Solution
函数内部,使用new
操作符动态创建一个Sum
类型的数组,数组大小为n
。这个操作会触发n
次Sum
的构造函数调用,从而按照上述逻辑累加从1到n的整数到Sum::ret
中。Sum::ret
的值,这个值就是1到n的整数和。delete[]
操作符释放之前动态分配的内存。Sum
类的静态成员变量ret
是私有的,需要一种方式来在Solution
类中访问它。这里使用了友元类的概念,将Solution
类声明为Sum
类的友元类,这样Solution
类就可以访问Sum
类的私有成员了。main
函数中,创建一个Solution
对象s1
,并调用其Sum_Solution
成员函数来计算1到10的和。通过这种方式,代码巧妙地利用了类的构造函数和静态成员变量,以及动态内存分配的特性,来绕过不能使用循环和条件判断的限制,实现了从1到n的整数求和。
class Sum
{
private:
static int count;
static int ret;
public:
friend class Solution;//友元类
Sum()
{
++count;
ret += count;
}
};
int Sum:: count = 0;
int Sum::ret = 0;
class Solution {
public:
int Sum_Solution(int n) {
new Sum[n];
return Sum::ret;
}
};