首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >检查Prime扩展

检查Prime扩展
EN

Stack Overflow用户
提问于 2016-07-25 17:03:32
回答 3查看 92关注 0票数 0

此方法应检查一个数字是否为质数

代码语言:javascript
复制
public static bool IsPrime(this long value)
{
    if (value < 2)
    {
        return false;
    }
    else
    {
        int boundary = (int)Math.Floor(Math.Sqrt(value));
        return Enumerable.Range(2, boundary-1).AsParallel().Any(x => value % x != 0);
    }
}

但并不是在所有情况下都有效。例如,根据这种方法,9是质数,但是3x3=9,所以它是错误的。我看不出这个方法有什么错误。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-07-25 17:11:20

忽略了这不能用于AsParallel()这一事实,您的问题是

代码语言:javascript
复制
return Enumerable.Range(2, boundary - 1).AsParallel().Any(x => value % x != 0);

应该是

代码语言:javascript
复制
return Enumerable.Range(2, boundary - 1).AsParallel().All(x => value % x != 0);

您应该一直在使用.All(),而不是.Any()

票数 3
EN

Stack Overflow用户

发布于 2016-07-25 17:17:34

反转条件:

代码语言:javascript
复制
return !Enumerable.Range(2, boundary - 1).AsParallel().Any(x => value % x == 0);
票数 2
EN

Stack Overflow用户

发布于 2016-07-25 17:09:01

您可以尝试以下更高效的代码:

代码语言:javascript
复制
  var primes = Enumerable.Range(1, 20)
    .Where(i => i != 1 && !Enumerable.Range(2, i - 2).Any(j => i % j == 0));
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38563591

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档