Euler Problem 1

[点击打开链接http://projecteuler.net/problem=1]

If we list all the natural numbers below 10 that are multiples of 3 or 5, we get 3, 5, 6 and 9. The sum of these multiples is 23.

Find the sum of all the multiples of 3 or 5 below 1000.

一,最直观的方法就是遍历,找出能被3或5整除的数,累加求和。

unsigned int sum = 0;
	int i;
	for( i = 1; i < 1000; i++)
	{
		if( (i % 3) == 0 || (i % 5) == 0 )
		{
			sum += i;
			printf("Multiple %d, SUM %d\n",i,sum);
		}
	}


二,利用容斥原理

在计数时,必须注意无一重复,无一遗漏。为了使重叠部分不被重复计算,人们研究出一种新的计数方法,这种方法的基本思想是:先不考虑重叠的情况,把包含于某内容中的所有对象的数目先计算出来,然后再把计数时重复计算的数目排斥出去,使得计算的结果既无遗漏又无重复,这种计数的方法称为容斥原理。(见百度百科)


其实就是集合运算里的一种方法:AUB = A + B - AB;


被3整除的自然数之和 SUM(3) = 1*3 + 2*3 + 3*3 + 4*3 + n*3...... = 3*(1+2+3+4+5+...+n) = 3 * n*(n+1)/2;


int Sum1ToN(int n)
{
	return n * ( n + 1 ) / 2;
}

int SumMultiples(int limit, int a)
{
	return Sum1ToN( (limit-1)/a ) * a;
}

	int sum = SumMultiples(1000,3) + SumMultiples(1000,5) - SumMultiples(1000,3*5);

	printf("Multiple , SUM %d\n",sum);



END

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值