PAT乙类1007之素数对猜想

一、题目


让我们定义d​n为:d​n=pn+1−pn,其中p​i是第i个素数。显然有d1=1,且对于n>1有d​n是偶数。“素数对猜想”认为“存在无穷多对相邻且差为2的素数”。
现给定任意正整数N(<10​^5),请计算不超过N的满足猜想的素数对的个数。输入格式:输入在一行给出正整数N。输出格式:在一行中输出不超过N的满足猜想的素数对的个数。输入样例:20输出样例:4

二、代码

方法一 :
  • 常用函数
  1. 本题目中需要自己掌握的就是素数的判断!!!在代码之后我详细介绍了素数的相关知识!!
  2. sqrt函数, 它不需要像在java中还需要Math.sqrt来调用,直接使用就行了。
  • 核心思想
    1)本题最为核心的是不在于如何判断素数,而在于素数判断成功后如何保存,保存后再进行比较!
    所以我选择了数组a[2], 没错只有两个元素,节省了很多空间。 它的存储数值是动态的,只要有两个数之后,不管满足不满足a[1] - a[0] == 2的条件,都要使a[0] = a[1], 让a[1]来存储新的素数!!!而且下标k也是动态变化的!!!!

  • bug调试过程

  1. 开始时,我的问题是n与i不分, 因为是不超过n的数进行遍历,所以这个i才是遍历的对象, 我在后面isPrime的时候用的n
    2)原文中是不超过n, 意思是包含n, 是i>=n
    3)我原来将k下标的修改位置放在了if条件a[1] - a[0] == 2之下,发现是错误的; 因为满足的只是少数,这样a[2]一直得不到更新
#include <iostream>
#include <math.h>
using namespace std;bool isPrime(int n) {if(n <= 3) {return n > 1;}int m = (int)sqrt(n);for(int i=2; i <= m; i++) {if(n % i == 0) {return false;}}return true;
}int main() {int n;cin>>n;int a[2];int  k = 0, sum = 0;for(int i=1; i<=n; i++) {if(isPrime(i)) {a[k] = i;k++;if(k == 2) {if(a[1] - a[0] == 2) {sum++;}a[0] = a[1];k = 1;}}}cout<<sum;return 0;
}

方法二:

在网上搜寻后,看到了另一种解决方法,感觉很简洁,分享一下!!

  • 核心思想
  1. 代码将 N<=4 和 N >=3 做了分割,是我们需要警惕的!!可能因为n = 2, 3,5都是质数(素数),只要2和3两个特殊!!
  2. 当n>3=时, 恢复正常判断。只需要一个 **isPrime(i) && isPrime(i + 2)**就可以判断出来, 让我很佩服!!!!

#include <stdio.h>
#include <math.h>
#include <stdbool.h>
bool isPrime(int);int main(void)
{int N,i;int count = 0;scanf("%d", &N);if (N <= 4)printf("0");else{for (i = 3; i <= N - 2; i++)if (isPrime(i) && isPrime(i + 2))count++;printf("%d",count);}	return 0;
}
bool isPrime(int n)
{int i;if (n == 1 || n == 0)return false;else{for (i = 2; i <= sqrt((double)n); i++)if (n%i == 0)return false;}return true;

三、素数(转载的)

作者:阿飞__
来源:CSDN
原文:https://blog.csdn.net/afei__/article/details/80638460
版权声明:本文为博主原创文章,转载请附上博文链接!

一、概念介绍

大家中学都学过,就不过多介绍了,大致提两点:

  • 质数又称素数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数。
  • 0和1既不是质数也不是合数,最小的质数是2

Attention!!! 最小的质数是 2!!!!! 所以当时1或者0的时候, 直接返回不是素数!!!

二、方法介绍

1.最直观,但效率最低的写法
public static boolean isPrime(int n){if (n <= 3) {return n > 1;}for(int i = 2; i < n; i++){if (n % i == 0) {return false;}}return true;
}

这里特殊处理了一下小于等于3的数,因为小于等于3的自然数只有2和3是质数。
然后,我们只需要从2开始,一直到小于其自身,依次判断能否被n整除即可,能够整除则不是质数,否则是质数。

2.初步优化

假如n是合数,必然存在非1的两个约数p1和p2,其中p1<=sqrt(n),p2>=sqrt(n)。由此我们可以改进上述方法优化循环次数。如下:

public static boolean isPrime(int n) {if (n <= 3) {return n > 1;}int sqrt = (int)Math.sqrt(n);for (int i = 2; i <= sqrt; i++) {if(n % i == 0) {return false;}}return true;
}
3.继续优化

我们继续分析,其实质数还有一个特点,就是它总是等于 6x-1 或者 6x+1,其中 x 是大于等于1的自然数。
如何论证这个结论呢,其实不难。首先 6x 肯定不是质数,因为它能被 6 整除;其次 6x+2 肯定也不是质数,因为它还能被2整除;依次类推,6x+3 肯定能被 3 整除;6x+4 肯定能被 2 整除。那么,就只有 6x+1 和 6x+5 (即等同于6x-1) 可能是质数了。所以循环的步长可以设为 6,然后每次只判断 6 两侧的数即可。

public static boolean isPrime(int num) {if (num <= 3) {return num > 1;}// 不在6的倍数两侧的一定不是质数if (num % 6 != 1 && num % 6 != 5) {return false;}int sqrt = (int) Math.sqrt(num);for (int i = 5; i <= sqrt; i += 6) {if (num % i == 0 || num % (i + 2) == 0) {return false;}}return true;
}

对于输入的自然数 n 较小时,也许效果不怎么明显,但是当 n 越来越大后,该方法的执行效率就会越来越明显了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/476370.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

case2

Codeuse dbTempcreate table test(Pid int identity(1,1) not null primary key,Years datetime,IsFirstSixMonths int default(0), --0表示上半年1表示下半年--TotalCome int) insert test select 2007-1-1,0,50union select 2007-3-1,0,60unionselect 2007-12-1,1,80union se…

LeetCode 916. 单词子集(计数)

1. 题目 我们给出两个单词数组 A 和 B。每个单词都是一串小写字母。 现在&#xff0c;如果 b 中的每个字母都出现在 a 中&#xff0c;包括重复出现的字母&#xff0c;那么称单词 b 是单词 a 的子集。 例如&#xff0c;“wrr” 是 “warrior” 的子集&#xff0c;但不是 “wor…

身份证城市代号python_身份证号码的地区代码分别是什么?

展开全部身份证号码的地区代码分别是&#xff1a;1、东北地区&#xff1a; 辽宁省|32313133353236313431303231363533e78988e69d8331333366303835210000&#xff0c;吉林省|220000&#xff0c;黑龙江省|230000&#xff0c;2、华北地区&#xff1a;北京市|110000&#xff0c;天津…

PAT乙类1008之数组元素循环右移问题

一、题目 一个数组A中存有N&#xff08;>0&#xff09;个整数&#xff0c;在不允许使用另外数组的前提下&#xff0c;将每个整数循环向右移M&#xff08;≥0&#xff09;个位置&#xff0c;即将A中的数据由&#xff08;A​0A1⋯AN−1变换为&#xff08;A​N−M⋯A​N−1A0A…

LeetCode 987. 二叉树的垂序遍历(递归/循环)

1. 题目 给定二叉树&#xff0c;按垂序遍历返回其结点值。 对位于 (X, Y) 的每个结点而言&#xff0c;其左右子结点分别位于 (X-1, Y-1) 和 (X1, Y-1)。 把一条垂线从 X -infinity 移动到 X infinity &#xff0c;每当该垂线与结点接触时&#xff0c;我们按从上到下的顺序…

Workflow WF Reference Links for 2009-03-20

Workflow Reference Links: 1. Model Portability in BPMN 2.0 Bruce Silver又再一次对BPMN2.0规范中的“可导出交换”能力发表了个人观点。银狐999对这篇文章做了一个博文导读。 2. BPMN Semantics “Vague” or Just Hard to Code? 有关BPMN与BPEL的映射的争论在继续…

PAT乙类1005之继续(3n+1)猜想 (25 分)

一、 题目 卡拉兹(Callatz)猜想已经在1001中给出了描述。在这个题目里&#xff0c;情况稍微有些复杂。 当我们验证卡拉兹猜想的时候&#xff0c;为了避免重复计算&#xff0c;可以记录下递推过程中遇到的每一个数。例如对 n3 进行验证的时候&#xff0c;我们需要计算 3、5、8、…

python各种岗位薪资_python编程语言岗位薪资真不是盖的

Python 起薪和均资都高于 Java? C表示&#xff1a;吃瓜看戏!本文爬取了某直聘网站上Python和Java的招聘信息&#xff0c;比较了两个方向的发展前(钱)途 &#xff0c;为本科生的就业方向给一个小小的建议。01、爬取在招聘网站上直接以”本科生”和”Java”或”Python”作为筛选…

LeetCode 456. 132模式(逆序遍历+单调栈)

1. 题目 给定一个整数序列&#xff1a;a1, a2, …, an&#xff0c;一个132模式的子序列 ai, aj, ak 被定义为&#xff1a;当 i < j < k 时&#xff0c;ai < ak < aj。 设计一个算法&#xff0c;当给定有 n 个数字的序列时&#xff0c;验证这个序列中是否含有132模…

一道题目

题目如下&#xff1a;有一500米环形跑道&#xff0c;甲、乙在同一点同向同时起跑&#xff0c;已知甲的速度为60米/分钟&#xff0c;乙的速度为50米/分钟。且甲、乙跑的过程中每跑200米都要停下休息1分钟。问&#xff1a;若甲追上乙一圈需要多少时间&#xff1f;本人比较笨&…

PAT乙类1009 说反话 (20 分)

一、 题目 给定一句英语&#xff0c;要求你编写程序&#xff0c;将句中所有单词的顺序颠倒输出。输入格式&#xff1a; 测试输入包含一个测试用例&#xff0c;在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成&#xff0c;其中单词是由英文字母&#xf…

python 控件叠加_如何将图像应用于控件背景(叠加)

我想为小部件分配一个背景图像&#xff0c;比如QListWidget或QWidget。这个想法是&#xff1a;理想的情况下&#xff0c;背景图像会随着控件大小的变化而调整大小。有什么办法吗&#xff1f;在稍后编辑&#xff1a;下面是这个对话框的屏幕截图&#xff0c;其中包含Salvatore提出…

LeetCode 447. 回旋镖的数量(哈希map+组合数)

1. 题目 给定平面上 n 对不同的点&#xff0c;“回旋镖” 是由点表示的元组 (i, j, k) &#xff0c;其中 i 和 j 之间的距离和 i 和 k 之间的距离相等&#xff08;需要考虑元组的顺序&#xff09;。 找到所有回旋镖的数量。你可以假设 n 最大为 500&#xff0c;所有点的坐标在…

老赵看博客园首页

不知道从什么时候开始&#xff0c;争论一篇文章是不是应该上首页成为博客园的一种流行。无论从任何角度出发&#xff0c;一旦谈起“文章质量”必然会有朋友会牵扯到“首页”&#xff08;见《和谐社区&#xff0c;和谐技术》&#xff09;&#xff0c;然后动辄又抡起一句“你没有…

PAT乙类1010之1010 一元多项式求导

一、题目 设计函数求一元多项式的导数。&#xff08;注&#xff1a;X​n&#xff08;n为整数&#xff09;的一阶导数为nXn−1。&#xff09;输入格式: 以指数递降方式输入多项式非零项系数和指数&#xff08;绝对值均为不超过 1000 的整数&#xff09;。数字间以空格分隔。输出…

此beta版本目前不接受任何新测试员_ASO行业资讯|苹果官方App测试工具TestFlight

ASO行业资讯1数据周报12月8日起&#xff0c;用户在任何 Apple 平台下载 App 之前&#xff0c;App Store 都会先帮助其了解该 App 的隐私保护做法。在每款 App 的产品页面上&#xff0c;用户能了解到该 App 可能收集的某些数据类型&#xff0c;以及该数据是否会关联到他们或对其…

c#执行存储过程的简单实例

/*登陆验证存储过程*/if exists(select name from sysobjects where typep and namecheckUserProc)drop procedure checkUserProcgocreate procedure checkUserProc(checkResult int output,checkUser varchar(50),checkPassword varchar(100))asif exists(select * from userT…

PAT乙类之1011 A+B 和 C

一、题目 给定区间 [−2​^31, 2 ^31​​ ] 内的 3 个整数 A、B 和 C&#xff0c;请判断 AB 是否大于 C。输入格式&#xff1a; 输入第 1 行给出正整数 T (≤10)&#xff0c;是测试用例的个数。随后给出 T 组测试用例&#xff0c;每组占一行&#xff0c;顺序给出 A、B 和 C。…

LeetCode 492. 构造矩形

1. 题目 作为一位web开发者&#xff0c; 懂得怎样去规划一个页面的尺寸是很重要的。 现给定一个具体的矩形页面面积&#xff0c;你的任务是设计一个长度为 L 和宽度为 W 且满足以下要求的矩形的页面。要求&#xff1a; 你设计的矩形页面必须等于给定的目标面积。 宽度 W 不应…

uuid生成_php如何生成 uuid(总结)

1、UUID的格式是什么&#xff1f;UUID格式为&#xff1a;xxxxxxxx-xxxx-xxxx-xxxxxx-xxxxxxxxxx (8-4-4-4-12)&#xff0c;其中每个 x 是 0-9 或 a-f 范围内的一个十六进制的数字2、UUID使用实例&#xff1f;用md5函数生成密码字符串&#xff0c;然后substr函数在里面截取就好&…