2025-03-04 学习记录--C/C++-C语言 判断是否是素数

合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。💪🏻

C语言 判断是否是素数

一、代码 ⭐️

c 复制代码
#include <stdio.h>
#include <stdbool.h> // 使用 bool 类型

// 判断是否是素数的函数
bool isPrime(int num) {
    if (num <= 1) {
        return false; // 素数要大于1
    }
    if (num == 2) {
        return true; // 2 是素数
    }
    if (num % 2 == 0) {
        return false; // 偶数(除了 2)不是素数
    }

    // 检查从 3 到 sqrt(num) 的奇数
    for (int i = 3; i * i <= num; i += 2) {
        if (num % i == 0) {
            return false; // 如果能被整除,则不是素数
        }
    }
    return true; // 否则是素数
}

int main() {
    int num;

    // 输入一个整数
    printf("请输入一个整数: ");
    scanf("%d", &num);

    // 调用函数判断是否是素数
    if (isPrime(num)) {
        printf("%d 是素数。\n", num);
    } else {
        printf("%d 不是素数。\n", num);
    }

    return 0;
} 

二、部分代码分析 ⭐️

c 复制代码
for (int i = 3; i * i <= num; i += 2) {
     if (num % i == 0) {
         return false; // 如果能被整除,则不是素数
     }
}

因为质数是只能被 1和它本身 整除的数,如果num不是质数的话,那么它应该就可以表示成a*b=num。如果ab都大于num的平方根的话,那么a*b就会大于num。就和前面a*b=num矛盾了。所以说a或者b肯定有一个是小于或等于num的平方根。因此for循环那里i*i<=num,后面那个i+=2是为了保证每次检查的num都是奇数,因为偶数除了2以外,必然不是质数。

如果一个数能通过平方根得出一个整数值,那么这个数肯定不是质数。所以那里的条件应该是i<=根号num。但是有可能是无理数,就不好比较啦。就通过i*i<=num来实现。

相关推荐
AI视觉网奇14 分钟前
ue 导出 fbx
笔记·学习·ue5
野犬寒鸦17 分钟前
从零起步学习并发编程 || 第三章:JMM(Java内存模型)详解及对比剖析
java·服务器·开发语言·分布式·后端·学习·spring
HyperAI超神经21 分钟前
覆盖天体物理/地球科学/流变学/声学等19种场景,Polymathic AI构建1.3B模型实现精确连续介质仿真
人工智能·深度学习·学习·算法·机器学习·ai编程·vllm
AI周红伟22 分钟前
周红伟:大模型的微调和 腾讯姚顺雨 刚发布“上下文学习”论文,的区别和联系
学习
近津薪荼39 分钟前
递归专题(4)——两两交换链表中的节点
数据结构·c++·学习·算法·链表
-Springer-43 分钟前
STM32 学习 —— 个人学习笔记2-1(软件安装)
笔记·stm32·学习
I'mChloe1 小时前
机器学习核心分支:深入解析非监督学习
人工智能·学习·机器学习
鱼很腾apoc1 小时前
【实战篇】 第14期 算法竞赛_数据结构超详解(下)
c语言·开发语言·数据结构·学习·算法·青少年编程
Gain_chance1 小时前
32-学习笔记尚硅谷数仓搭建-DWD层首日数据装载脚本及每日数据装载脚本
大数据·数据仓库·hive·笔记·学习
神奇小梵1 小时前
c语言易错知识点
c语言·开发语言