《剑指offer》:1+2+3+....+n

【问题描述】:
编程求1+2+3+…+n
要求:不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句。

【解决思路】: 
这个题目如果没有加要求对每一个都比较熟悉,也都可以求解。我们能够想到的方法有 
(1)递归 
(2)循环累加 
(3)等差数列求和公式 
例如:
#include<stdio.h>
#include<windows.h>
int Sum(int n)
{
	if (1 == n)
	{
		return 1;
	}
	return n + Sum(n - 1);
}
int main()
{
	int num = 3;
	int ret=Sum(num);
	printf("%d\n", ret);
	system("pause");
	return 0;
}

由于题目的要求,我们不能直接使用乘除法、循环等,因此上面的方法不太适用。 那么我们应该怎么做呢?

递归实现,一般的递归写法就是上边代码的写法,要想不使用if,else等判断条件使用递归我们只能另想办法找到递归终止条件和逼近条件。
代码如下:
#include<stdio.h>
#include<windows.h>
int Sum(int n)
{
	int result = 0;
	n && (result = n + Sum(n - 1));
	//这里可以就很好的避免了使用if判断
	return result;
}
int main()
{
	int num = 0;
	scanf_s("%d", &num);
	int ret=Sum(num);
	printf("%d\n", ret);
	system("pause");
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值