当前位置: 首页 > web >正文

Go语言实战案例-判断一个数是否为质数

在《Go语言实战案例》中 案例11:判断一个数是否为质数 的完整内容,适合初学者练习条件判断、循环控制与函数编写。


案例11:判断一个数是否为质数

🔢 数学判断 | 🔁 循环与条件 | 🧠 初阶逻辑思维训练


一、案例目标

编写一个程序,判断用户输入的正整数是否是质数(又称素数)。


二、应用场景举例

  • • 数学题目求解
  • • 加密算法中的大质数判定(如RSA)
  • • 数学建模、筛选质数列表等

三、涉及知识点

知识点说明
质数定义只能被 1 和它本身整除的自然数(大于1)
for 循环判断是否能被其他数整除
条件语句if / else 判断是否满足质数条件
函数封装判断逻辑封装为独立函数

四、功能需求

  1. 1. 用户输入一个正整数;
  2. 2. 判断该数是否为质数;
  3. 3. 输出“是质数”或“不是质数”。

五、完整代码实现

package mainimport ("fmt""math"
)// 判断一个数是否为质数
func isPrime(n int) bool {if n <= 1 {return false}sqrtN := int(math.Sqrt(float64(n)))for i := 2; i <= sqrtN; i++ {if n%i == 0 {return false}}return true
}func main() {var num intfmt.Print("请输入一个正整数:")fmt.Scanf("%d", &num)if isPrime(num) {fmt.Printf("%d 是一个质数。\n", num)} else {fmt.Printf("%d 不是一个质数。\n", num)}
}

六、示例运行

示例1:
请输入一个正整数:13
13 是一个质数。
示例2:
请输入一个正整数:20
20 不是一个质数。

七、核心实现解析

func isPrime(n int) bool {if n <= 1 {return false // 小于等于1的数不是质数}sqrtN := int(math.Sqrt(float64(n))) // 只判断到√n即可for i := 2; i <= sqrtN; i++ {if n%i == 0 {return false // 存在其他因数}}return true
}
  • • 用平方根优化判断范围是为了提升效率;
  • • 如果 n 能被 [2, √n] 中的任意一个整除,就不是质数;
  • • 函数封装后主函数调用简单、易于维护。

八、拓展建议

  1. 1. 批量判断多个数字是否为质数
  2. 2. 输出某个区间内的所有质数
  3. 3. 实现埃拉托色尼筛法生成质数表
  4. 4. 支持输入负数与非法值并提示错误
  5. 5. 用并发判断多个数是否为质数(goroutine)

🔚 小结

本案例锻炼了你对:

  • • 条件判断;
  • • 循环控制;
  • • 数学基础逻辑(质数定义);
  • • 函数封装;

的掌握和应用。

✅ 质数判断是很多算法和加密技术的基础逻辑,掌握它为进阶算法打下基础。


http://www.xdnf.cn/news/15838.html

相关文章:

  • 路由器的Serial 串口理解
  • 【安卓笔记】RxJava的Hook机制,整体拦截器
  • AWS Partner: Sales Accreditation (Business)
  • 从零构建监控系统:先“完美设计”还是先“敏捷迭代”?
  • 智能点餐推荐网站,解决选择困难
  • AE PDW2200电源射频手侧使用安装说明含电路图
  • 谷歌地球与ArcGIS Pro查看三维地形
  • 深入解析Linux文件描述符:原理、机制与应用实践
  • 使用 C# 实现移动加权平均(Weighted Moving Average)算法
  • js中 new Set()实例的各个api使用
  • Java学习------ConcurrentHashMap
  • Honeywell霍尼韦尔DV-10 变速器放大器 输入 15-28 VDC,输出 +/- 10VDC 060-6881-02
  • 【53】MFC入门到精通——MFC串口助手(二)---通信版(发送数据 、发送文件、数据转换、清空发送区、打开/关闭文件),附源码
  • 软件维护全维度解析:从修复到进化的生命周期管理
  • mave手动下载某个依赖,到本地库
  • IP协议深入理解
  • C语言实战:超级玛丽游戏
  • 组件-多行文本省略-展开收起
  • 百炼MCP与IoT实战(三):手搓自定义MCP Server与阿里云FC配置
  • 40+个常用的Linux指令——上
  • halcon模版匹配方向的研究
  • ts学习2
  • 飞算科技:以创新科技引领数字化变革,旗下飞算 JavaAI 成开发利器
  • 人脸检测算法——SCRFD
  • 可靠消息最终一致性分布式事务解决方案
  • 基础密码协议
  • Xilinx Zynq:一款适用于软件定义无线电的现代片上系统
  • 代理模式及优化
  • 手撕Spring底层系列之:Bean的生命周期
  • C++进阶-红黑树(难度较高)