http://projecteuler.net/problem=1
如果我们列出所有小于 10 且是 3 或 5 的倍数的自然数,我们会得到 3、5、6 和 9。这些倍数的和是 23。求出 1000 以下的所有 3 或 5 的倍数之和。
如果我将“int maxNum”更改为 10 或任何其他小数字(如 20),我将得到正确答案。
但不知何故,当我用一个像 1000 这样的大数字做它时,它会给我一个我不希望出现的数字,我不知道为什么,请帮忙。
它这样做是因为它已经达到了 int 的最大值吗?
class Program
{
static void Main(string[] args)
{
//TASK: 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.
int multiplierA = 3;
int multiplierB = 5;
int maxNum = 1000;
int i = 1;
int deelEen = MultiplyFactory(multiplierA, i, maxNum);
int deelTwee = MultiplyFactory(multiplierB, i, maxNum);
int result = deelEen + deelTwee;
Console.WriteLine(result);
Console.Read();
}
static int MultiplyFactory(int multiplier, int i, int maxNum)
{
List<int> savedNumbers = new List<int>();
while(multiplier*i < maxNum)
{
savedNumbers.Add(multiplier*i);
i++;
}
int answer = 0;
foreach(int getal in savedNumbers)
{
Console.WriteLine(getal);
answer = answer + getal;
}
savedNumbers.Clear();
return answer;
}
}