PAT乙级1007.素数对猜想(20分)

简介: PAT乙级1007.素数对猜想(20分)

题目描述:

让我们定义dn 为:dn=pn+1−pn,其中pi是第i个素数。显然有d

1

=1,且对于n>1有d

n

是偶数。“素数对猜想”认为“存在无穷多对相邻且差为2的素数”。


现给定任意正整数N(<10

5

),请计算不超过N的满足猜想的素数对的个数。


输入格式:

输入在一行给出正整数N。


输出格式:

在一行中输出不超过N的满足猜想的素数对的个数。


输入样例:

20

输出样例:

4


解题思路:

这道题因为运行超时卡住了

原先的思路,先写一个函数判断是不是素数,然后把这些素数装在一个vector中,然后再进行统计相邻两个数之间是不是相差2;结果超时了。

大佬思路:

判断素数的函数isprime这样写:对于数字a,i从2到根号a,如果a能够被其中一个i整除,说明i不是素数,return false,否则说明a是素数return true;对于输入数据N,for循环中的i从5到N依次判断i-2和i是否是素数,如果都是素数,则统计个数的cnt++,最后输出cnt即可,

这个就是把相邻差2的数字判断一下是不是素数,还有判断素数的函数也比较简单。

解题代码:

#include<iostream>
using namespace std;
bool isprime (int a){//自定义一个函数判断是否为素数 
  for(int i=2;i*i<=a;i++){
    if(a%i==0){
      return false;
    }
  }
  return true;
}
int main() {
  int n;
  int sum=0;
  cin>>n;
  for(int i=5; i<=n; i++) {
    if(isprime(i-2)&&isprime(i)){
      sum++;
    }
  }
  cout<<sum;
  return 0;
}
相关文章
|
6月前
|
算法 测试技术
枚举(蓝桥练习)(反倍数、特别数的和、找到最多的数、小蓝的漆房、小蓝和小桥的挑战)
枚举(蓝桥练习)(反倍数、特别数的和、找到最多的数、小蓝的漆房、小蓝和小桥的挑战)
|
6月前
|
机器学习/深度学习 人工智能 算法
【代数学作业1完整版-python实现GNFS一般数域筛】构造特定的整系数不可约多项式:涉及素数、模运算和优化问题
【代数学作业1完整版-python实现GNFS一般数域筛】构造特定的整系数不可约多项式:涉及素数、模运算和优化问题
123 0
|
6月前
|
C语言
(浙大版《C语言程序设计(第3版)》 习题6-5 使用函数验证哥德巴赫猜想 (20分)
(浙大版《C语言程序设计(第3版)》 习题6-5 使用函数验证哥德巴赫猜想 (20分)
|
存储 算法 Python
信息学奥赛 试除法:高效筛选素数的算法
本文介绍了在Python代码中如何使用试除法高效筛选素数。
128 0
786. 第 K 个最小的素数分数【我亦无他唯手熟尔】
786. 第 K 个最小的素数分数【我亦无他唯手熟尔】
48 0
|
C++ Python
【浙江大学PAT真题练习乙级】1007 素数对猜想 (20分) 真题解析
【浙江大学PAT真题练习乙级】1007 素数对猜想 (20分) 真题解析
|
数据采集 数据挖掘 Python
【每周一坑】验证哥德巴赫猜想
尽管对于大多数人来说,无法看懂哥德巴赫猜想及相关问题的证明。不过我们借助计算机,可以快速地判断一个数是否符合哥德巴赫猜想。(只需在判断质数的代码基础上加上两三行。)
(博弈)(思维)(试除法判断质数)B - 是我仅会的GCD还是素数筛呢? G. Goodbye
(博弈)(思维)(试除法判断质数)B - 是我仅会的GCD还是素数筛呢? G. Goodbye
54 0
|
测试技术
PAT乙级1005.继续(3n+1)猜想(25分)
PAT乙级1005.继续(3n+1)猜想(25分)
84 0
|
机器学习/深度学习 测试技术
PAT乙级1001 害死人不偿命的(3n+1)猜想 (15分)
PAT乙级1001 害死人不偿命的(3n+1)猜想 (15分)
84 0