1+2+3+...+n不能用while、for、if else等实现

本文介绍了一种利用模板、递归、类构造函数和虚函数的方法来计算从1到n的和,而无需使用乘除法、while、for、if、else、switch等条件判断语句。通过实例展示了多种解决思路,并讨论了每种方法的优缺点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

全题为不能用乘除法,while for if else switch 条件判断语句等实现

1+2+3+...+n

首先不难想到的是编译期求解,即使用模板

code如下:

[cpp]  view plain copy
  1. /*   
  2. * Copyright (c) 2011 alexingcool. All Rights Reserved.   
  3. */   
  4. #include <iostream>  
  5.   
  6. using namespace std;  
  7.   
  8. template<int n>  
  9. class plus {  
  10. public:  
  11.     enum value { result = plus<n - 1>::result + n };  
  12. };  
  13.   
  14. template<>  
  15. class plus<1> {  
  16. public:  
  17.     enum value { result = 1 };  
  18. };  
  19.   
  20. void main()  
  21. {  
  22.     class plus<100> plus;  
  23.     cout << "plus.result = " << plus.result << endl;  
  24. }  
 

本方法有两个极大的缺陷:其一,class plus<100> plus里的100是手动设定的;其二,本题的实质是递归,但和递归不一样的是编译期求解,所以深度是有限的,试了下class plus<1000> plus就已经出问题了。

上述方法实质上属递归,普通递归也是可以实现的,不过方法很蛋疼,基本是想不出来的,code如下

[cpp]  view plain copy
  1. #include <iostream>  
  2.   
  3. using namespace std;  
  4.   
  5. int recurPlus(int n)  
  6. {  
  7.     //i = 1是必须的,当n = 1的时候返回i需要初值  
  8.     int i = 1;  
  9.     (n > 1) && (i = recurPlus(n - 1) + n);  
  10.     return i;  
  11. }  
  12.   
  13. void main()  
  14. {  
  15.     int i = recurPlus(100);  
  16.     cout << "i = " << i << endl;  
  17. }  

 

下面一个方法是利用类的构造函数来实现,这个比较容易理解:

[cpp]  view plain copy
  1. #include <iostream>  
  2.   
  3. using namespace std;  
  4.   
  5. class Plus  
  6. {  
  7. public:  
  8.     Plus() { ++i, sum += i; }  
  9.     //去掉下面的reset函数试试  
  10.     static void reset() { i = 0; sum = 0; }  
  11.     //去掉下面的static关键字试试  
  12.     static int getSum() { return sum; }  
  13.   
  14. private:  
  15.     static int i;  
  16.     static int sum;  
  17. };  
  18.   
  19. int Plus::i = 0;  
  20. int Plus::sum = 0;  
  21.   
  22. int cacSum(int n)  
  23. {  
  24.     //只有static函数才能如此调用  
  25.     Plus::reset();   
  26.   
  27.     Plus *test = new Plus[n];  
  28.     delete[] test;  
  29.   
  30.     return Plus::getSum();  
  31. }  
  32.   
  33. void main()  
  34. {  
  35.     int i = 100;  
  36.     int result = cacSum(i);  
  37.     cout << "result = " << result << endl;  
  38.     result = cacSum(i);  
  39.     cout << "result = " << result << endl;  
  40. }  

 

网上还有一种利用虚函数的解法,更蛋疼

[cpp]  view plain copy
  1. #include <iostream>  
  2.   
  3. using namespace std;  
  4.   
  5. class A;  
  6. A* Array[2];  
  7.   
  8. class A  
  9. {  
  10. public:  
  11.     virtual int Sum (int n) { return 0; }  
  12. };  
  13.   
  14. class B: public A  
  15. {  
  16. public:  
  17.     virtual int Sum (int n) { return Array[!!n]->Sum(n - 1) + n; }  
  18. };  
  19.   
  20. int cacSum(int n)  
  21. {  
  22.     A a;  
  23.     B b;  
  24.     Array[0] = &a;  
  25.     Array[1] = &b;  
  26.   
  27.     int value = Array[1]->Sum(n);  
  28.   
  29.     return value;  
  30. }  
  31.   
  32. void main()  
  33. {  
  34.     int i = 2;  
  35.     int result = cacSum(i);  
  36.     cout << "result = " << result << endl;  
  37. }  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值