C++--求1+2+3+...+n=?
【摘要】 1+2+3+…+n=?
题目 求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)
方法(递归)
#include<iostream>
using namespace std;
//利用短路求值 与操作
int sum(int n)
{
int x=n;
x&...
1+2+3+…+n=?
题目
求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)
方法(递归)
#include<iostream>
using namespace std;
//利用短路求值 与操作
int sum(int n)
{
int x=n;
x&&(x+=sum(n-1));
return x;
}
int main()
{
cout<<"1+2+3+...+100="<<sum(100)<<endl;
return 0;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18

总结
这里需要用到递归的方法,但是使用递归必须有终止递归条件,由于条件限制,所以这里想到可以用短路求值的方法进行终止条件的判定,利用与操作,当与前一个操作数为0的时候,会终止与操作
文章来源: haihong.blog.csdn.net,作者:海轰Pro,版权归原作者所有,如需转载,请联系作者。
原文链接:haihong.blog.csdn.net/article/details/102597044
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)