💓 博客主页:倔强的石头的CSDN主页****
📝Gitee主页:倔强的石头的gitee主页****
⏩ 文章专栏:
期待您的关注
题目描述:
原题链接:
求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的整数求和。
C++实现代码:
cpp
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;
}
};