OCAC暑期比赛第一场 L题 判断素数 题解

Posted ocac

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了OCAC暑期比赛第一场 L题 判断素数 题解相关的知识,希望对你有一定的参考价值。

判断素数
【题目描述】
素数,是指除了一和它本身外,不能被别的书整除的数。
给你一个整数数 a (0 <= a <= 10^18) ,请你判断它是不是素数。
【输入格式】
输入一个整数 a (0 <= a <= 10^18)。
【输出格式】
如果 a 是素数,输出 "YES";否则,输出 "NO" 。
【样例输入1】
8
【样例输出1】
NO
【样例输入2】
13
【样例输出2】
YES
【题目分析】
对于一个数 a, 从 2 到 sqrt(a) 找找有没有能够整除 a 的数。
实现代码如下:

#include <bits/stdc++.h>
using namespace std;

long long a;

bool check() 
    if (a < 2) return false;
    for (long long i = 2; i * i <= a; i ++) 
        if (a % i == 0) return false;
    
    return true;


int main() 
    cin >> a;
    puts(check() ? "YES" : "NO");
    return 0;

 

以上是关于OCAC暑期比赛第一场 L题 判断素数 题解的主要内容,如果未能解决你的问题,请参考以下文章

OCAC暑期比赛第一场 G题 男孩或者女孩 题解

OCAC暑期比赛第一场 E题 有用的数学 题解

OCAC暑期比赛第一场 D题 足球比赛中的危险状态 题解

OCAC暑期比赛第一场 K题 最大公约数 题解

OCAC暑期比赛第一场 F题 字符串加密 题解

OCAC暑期比赛第一场 B题 字符串任务 题解