[点击打开链接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