我下面的代码number
通过创建一个素数列表并检查下一个潜在素数是否可以被列表中的任何素数整除来找到下面的所有素数。
我正在努力学习 的来龙去脉yield return
。现在我有一个List<int> primes
我在函数内部使用的。但我通过返回相同的数据yield return
。所以我的问题是
我可以在创建 IEnumerable< int > 时从函数内部访问它吗?所以我可以完全删除 List< int > 素数。
/// <summary>
/// Finds all primes below <paramref name="number"/>
/// </summary>
/// <param name="number">The number to stop at</param>
/// <returns>All primes below <paramref name="number"/></returns>
private static IEnumerable<long> PrimeNumbers(long number)
{
yield return 2;
List<long> primes = new List<long>(2);
for(long num = 3; num < number; num += 2)
{
//if any prime lower then num divides evenly into num, it isn't a prime
//what I'm doing now
if(!primes.TakeWhile(x => x < num).Any(x => num % x == 0))
{
primes.Add(num);
yield return num;
}
//made-up syntax for what I'd like to do
if(!this.IEnumerable<long>
.TakeWhile(x => x < num).Any(x => num % x == 0))
{
yield return num;
}
}
}