0

0

C#怎么判断一个数字是否为素数_C#如何编写数学逻辑算法【教程】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-03-19 11:54:01

|

124人浏览过

|

来源于php中文网

原创

最稳妥的IsPrime实现是:n<2返回false,n==2返回true,n为偶数返回false,再从3开始试除到(int)Math.Sqrt(n)(含)的奇数;因√n已覆盖所有因子配对,用n/2会显著降低性能。

c#怎么判断一个数字是否为素数_c#如何编写数学逻辑算法【教程】

直接说结论:用 Math.Sqrt 配合 % 取余循环,是最常用也最稳妥的判断方式;别用试除到 n-1,更别信“只除奇数就行”这种半吊子优化。

怎么写一个靠谱的 IsPrime 函数

核心逻辑就一条:从 2 试除到 (int)Math.Sqrt(n)(含),中间有任何一个能整除,就不是素数。注意边界处理——1 不是素数,2 是素数,负数和 0 直接返回 false

实操建议:

  • n < 2 立刻返回 false01、负数全拦住)
  • n == 2 直接返回 true(唯一偶素数)
  • n % 2 == 0 返回 false(排除其他所有偶数)
  • 3 开始,只试除奇数,步长为 2,上限取 (int)Math.Sqrt(n)(不是 n / 2,也不是 n - 1

示例片段:

static bool IsPrime(int n)
{
    if (n < 2) return false;
    if (n == 2) return true;
    if (n % 2 == 0) return false;
    for (int i = 3; i <= (int)Math.Sqrt(n); i += 2)
        if (n % i == 0) return false;
    return true;
}

为什么必须用 Math.Sqrt 而不是 n / 2

因为如果 n 有大于 √n 的因子,那它一定对应一个小于 √n 的配对因子。试除到 √n 就覆盖了全部可能性。用 n / 2 会多跑几倍循环,对大数(比如 1000003)性能差距明显。

容易踩的坑:

WisPaper
WisPaper

复旦大学研发的AI学术搜索工具,5分钟内筛选1000篇论文

下载
  • Math.Sqrt 返回 double,强制转 int 会向下取整,但不影响正确性(比如 √100 = 10.010√99 ≈ 9.959,而 9 已足够)
  • 忘了加等号 <=,比如 i < Math.Sqrt(n) 会让 25 错判成素数(5 没被试除)
  • float 或没转 int 直接参与循环变量,编译不过或隐式转换出错

long 类型怎么办?Math.Sqrt 还好使吗

longMath.Sqrt 接收 double,而 double 只能精确表示最多约 2^53 的整数,超过这个范围(比如 long.MaxValue2^63)时,Math.Sqrt 返回值会丢失精度,导致上限算错、漏判。

实操建议:

  • 小范围 long(比如 < 10^12)仍可用 (long)Math.Sqrt(n),问题不大
  • 真要处理超大数,改用二分法找整数平方根,或用 BigInteger.IsProbablePrime(需 .NET 5+,且是概率算法)
  • 更简单粗暴的做法:循环条件写成 i <= n / i,避免开方——n / i >= i 等价于 i * i <= n,不依赖浮点,也无溢出风险(前提是 i 不太大)

常见错误现象和调试线索

你写的 IsPrime 返回结果不对?先盯这几个点:

  • 输入 4 返回 true → 没处理 n % 2 == 0 的情况,或者循环从 2 开始但没包含 2
  • 输入 25 返回 true → 上限用了 < 而不是 <=i 没走到 5
  • 输入 -5 报异常或返回 true → 缺少 n < 2 检查
  • 大数(如 1000000007)卡住或超时 → 循环上限写成了 n / 2n - 1

素数判断本身不复杂,但边界和数值类型转换这两个地方,最容易在上线后悄悄翻车。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c#是什么意思
c#是什么意思

C#是一种通用的面向对象编程语言,它在.NET框架上运行,可用于开发各种类型的应用程序。本专题为大家提供c#相关的各种文章、以及下载和课程。

279

2023.08.08

什么是c#
什么是c#

C#(读作C Sharp)是一种现代的、通用的、面向对象的编程语言。它由微软公司开发,于2000年首次发布,主要用于开发Windows桌面应用程序、Web应用程序、移动应用程序以及游戏开发等领域。C#是一种类型安全和托管的编程语言,它结合了C++的强大性能和C语言的简单易学特点,并引入了许多新的特性和概念,如委托、属性、泛型和异步编程等,以提高开发效率和代码可维护性。

185

2023.08.31

C#中base关键字的用法
C#中base关键字的用法

在C#中,base关键字用于访问当前类的基类成员,这包括基类的字段、属性、方法、构造函数、索引器以及事件。想了解更多C#的相关内容,可以阅读本专题下面的文章。

327

2024.03.13

C#Task用法
C#Task用法

Task在C#中是用于表示异步操作的对象,它位于System.Threading.Tasks命名空间中。想了解更多C#中各种用法的相关内容,可以阅读本专题下面的文章。

380

2024.03.14

C# 并发与异步编程
C# 并发与异步编程

本专题系统讲解 C# 异步编程与并发控制,重点介绍 async 和 await 关键字、Task 类、线程池管理、并发数据结构、死锁与线程安全问题。通过多个实战项目,帮助学习者掌握 如何在 C# 中编写高效的异步代码,提升应用的并发性能与响应速度。

29

2026.02.03

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

107

2026.02.06

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

416

2026.03.11

bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

22

2026.03.18

bootstrap框架介绍
bootstrap框架介绍

本专题整合了bootstrap框架相关介绍,阅读专题下面的文章了解更多详细内容。

137

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 11.6万人学习

C 教程
C 教程

共75课时 | 5.6万人学习

C++教程
C++教程

共115课时 | 22.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号