hnust 1100 实验3-2:素数判断

hnust 1100 实验3-2:素数判断

题目描述

判断正整数x是否为素数。

质数又称素数。指在一个大于1的自然数中,除了1和此整数自身外,没法被其他自然数整除的数。换句话说,只有两个正因数(1和自己)的自然数即为素数。比1大但不是素数的数称为合数。1和0既非素数也非合数。

输入

先输入一个整数n(表示后面要输入n个测试数据);

然后输入n个测试数据,每个测试数据是一个正整数x。

输出

与n个输入的正整数x相对应,输出判断结果。如果是素数,输出"Yes",不是素数,输出"No"。

样例输入 Copy

5

7

8

795

181

888

样例输出 Copy

Yes

No

No

Yes

No

提示

本题由教材例3-18改编而成。

本题难度系数为4。

解题过程

一个简单的素数检测程序,用于判断用户输入的一系列整数是否为素数。

下面是对代码的详细解析:

  1. 头文件

    • 包含 <bits/stdc++.h> 头文件,这是一个常用的头文件,包含了标准库中的大部分内容,以及一些竞赛编程中常用的额外头文件。
  2. 命名空间

    • 使用 using namespace std; 来避免在标准库类型和函数前加 std::
  3. 素数检测函数 prime

    • 接收一个整数 x 作为参数。
    • 如果 x 等于1,直接返回 false,因为1不是素数。
    • 使用一个 for 循环从2遍历到 x/i,检查 x 是否能被其中任何数整除。
    • 如果 x 能被整除,返回 false 表示 x 不是素数。
    • 如果循环结束后没有找到整除的数,返回 true 表示 x 是素数。
  4. 主函数 main

    • 首先读取一个整数 j,表示接下来有多少组测试数据。
    • 使用一个 for 循环,从1到 j(包括 j),处理每组测试数据。
    • 在每次循环中,读取一个整数 n,表示要检测的数。
    • 调用 prime 函数判断 n 是否为素数。
    • 根据 prime 函数的返回值,输出 "Yes" 或 "No"。
  5. 程序结束

    • 输入结束后,程序返回0,表示正常结束。

代码逻辑分析

  • 这段代码首先读取测试数据组数,然后对于每组数据,读取一个整数并判断它是否为素数。
  • 使用了素数的基本定义来实现判断逻辑,即一个数如果除了1和它本身外没有其他因数,则为素数。

潜在问题

  • prime 函数的时间复杂度较高,对于大数的素数检测效率较低。
  • prime 函数没有考虑 x 为负数或0的情况,虽然这不是素数检测的常见情况。

改进建议

  • 考虑优化 prime 函数,例如只检查到 sqrt(x),因为如果 x 是合数,它必定有一个不大于 sqrt(x) 的因数。
  • 可以添加对输入数据有效性的检查,确保读取的是有效的整数。
  • 考虑使用更现代的C++特性,如 std::vector,以提高代码的灵活性和健壮性。

部分代码

代码如下( 素数判断。):

c 复制代码
bool prime(int x){
    if(x==1)return 0;
    for(int i=2;i<=x/i;i++)
        if(x%i==0)return 0;
    return 1;
}

AC代码

c 复制代码
#include<bits/stdc++.h>
using namespace std;
bool prime(int x){
    if(x==1)return 0;
    for(int i=2;i<=x/i;i++)
        if(x%i==0)return 0;
    return 1;
}
int main()
{
    int j;cin>>j;int n;
    for(int i=1;i<=j;i++)
    {
        cin>>n;
        if(prime(n)){cout<<"Yes"<<endl;}
        else cout<<"No"<<endl;
    }
     
    return 0;
}
相关推荐
黄敬峰8 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术9 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六12 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术13 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize13 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营1 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
用户805533698032 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
To_OC2 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode