啊哈c语言——逻辑挑战8:验证哥德巴赫猜想

         上面这封书信是普鲁士数学家哥德巴赫在1742年6月7日写给瑞士数学家欧拉的,哥德巴赫在书信中提出了“任一大于2的整数都可以写成3个质数之和”的猜想。当时,哥德巴赫遵照的是“1也是素数”的约定。现今,数学界已经不使用这个约定了。哥德巴赫原猜想在现代被陈述为: 任一大于5的整数都可写成3个质数之和。1742年6月30日欧拉在回信中注明,此猜想可以有另一个等价的版本,即“任一大于2的偶数都可写成 两个质数之和”。

        我们现在所说的哥德巴赫猜想通常是指这个版本。两个多世纪过去 了,这一猜想既无法证明,也没有被推翻。我们现在将通过程序在4~ 100内验证这个猜想。

        让我们来验证4~100内所有偶数都可写成两个质数之和。首先4~ 100的偶数循环可以这样写:

         然后我们需要将每一个数k 拆分为a +b 的形式,a 的范围是2~k /2(自己想一想为什么到k /2就可以了)。如果a 和b都是质数的话我们就将其打印出来,说明对于数k我们验证成功了,然后继续验证下一个数。打印的效果如下:

         补充一点:上面的10还可以拆分为5+5,14还可以拆分为7+7。代码框架如下:

         通过之前的学习,我们已经掌握了如何判断一个数是否为质数。我们将判断质数的代码融合到上面的代码中,完整的代码如下:

#include <stdio.h>
#include <stdlib.h>
int main()
{int k, a, b, i, count1, count2;for(k=4; k<=100; k=k+2){for(a=2; a<=k/2; a++){//判断a是否为质数count1=0;for(i=2; i<=a-1; i++){if(a%i==0){count1++;break;}}if(count1==0) //如果a为质数{b=k-a;//判断b是否为质数count2=0;for(i=2; i<=b-1; i++){if(b%i==0){count2++;break;}}if(count2==0) //如果b也是质数{printf("%d=%d+%d\n", k, a, b);break; //打印这个解并跳出循环}}}}system("pause");return 0;
}

这里只验证了从4到100的数,你也可以验证更大的范围。当然,去验证哥德巴赫猜想有很多种方法,显然这种方法是不够好的,判断质数的部分也不够快,这里只是提供一种思路,我想你一定可以找到更高效的方法。

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

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

相关文章

safari缓存清理

safari缓存清理 点击顶端Safari浏览器–>点击偏好设置 点击隐私–>管理网站数据 全部移除

前端页面锚点跳转

一&#xff0c;页面 二&#xff0c;获取需要跳转的标签class或者id 三&#xff0c;调用跳转方法 如果你的标签有唯一的ID&#xff0c;那么用getElementById方法更好 点击即可跳转锚点

日常工作 经验总结

1,在使用vue2开发项目时,快捷有效的组件化component 若有参数传递时,可以通过这样传递 在component中: 2,上拉加载,下拉刷新 若是使用局部进行上拉加载 下拉刷新 且需要用到scroll-view时 那么需要切记scroll-view在内被mescroll-uni包裹。若场景有限 对于无数据显示…

DevOps(11)

目录 66.在完全部署到所有用户之前&#xff0c;有哪些方法可以测试部署&#xff1f; 67.什么是持续测试? 68.如何做版本管理&#xff1f; 69.为什么要有监控系统&#xff1f;谈谈你对监控的理解&#xff1f; 70.监控体系监控哪些内容&#xff1f; 71.监控一般采用什么样的…

springboot、spring-kafka、kafka-client的版本对应关系

在使用springboot集成kafka的时候需要注意springboot版本、引用的依赖spring-kafka版本和kafka中间件版本的对应关系&#xff0c;否则可能会因为版本不兼容导致出现错误。 1、含义说明&#xff08;摘自官网&#xff09; Spring Boot&#xff1a;是springboot的版本。Spring fo…

推荐几个免费的HTTP接口Mock网站和工具

在前后端分离开发架构下&#xff0c;经常遇到调用后端数据API接口进行测试、集成、联调等需求&#xff0c;比如&#xff1a; &#xff08;1&#xff09;前端开发人员很快开发完成了UI界面&#xff0c;但后端开发人员的API接口还没有完成&#xff0c;不能进行前后端数据接口对接…

视频剪辑指南:如何将多个视频快速批量合并的方法

在日常生活和工作中&#xff0c;经常要将多个视频片段合并为一个完整的视频。但是手动剪辑每个视频不仅费时&#xff0c;而且效率低下。那么如何解决这个问题呢&#xff0c;可以采用一些快速批量合并视频的方法。现在一起来看看云炫AI智剪如何批量合并视频的具体步骤吧。 合并…

Jenkins集成部署java项目

文章目录 Jenkins简介安装 Jenkins简介 Jenkins能实时监控集成中存在的错误&#xff0c;提供详细的日志文件和提醒功能&#xff0c;还能用图表的形式形象的展示项目构建的趋势和稳定性。 官网 安装 在官网下载windows版本的Jenkins 但是我点击这里浏览器没有反应&#xff0…

bootstrap4实现汽车销售网页Motodeal的设计

一、需求分析 汽车销售网页是指用于展示和销售汽车产品的网站。它的功能主要包括以下几个方面&#xff1a; 产品展示&#xff1a;汽车销售网页通常会展示各种汽车品牌和型号的详细信息&#xff0c;包括外观照片、内饰设计、技术规格、性能参数等。这些信息可以帮助潜在买家了解…

【UnityShader入门精要学习笔记】(2)GPU流水线

本系列为作者学习UnityShader入门精要而作的笔记&#xff0c;内容将包括&#xff1a; 书本中句子照抄 个人批注项目源码一堆新手会犯的错误潜在的太监断更&#xff0c;有始无终 总之适用于同样开始学习Shader的同学们进行有取舍的参考。 文章目录 上节复习GPU流水线顶点着色…

企业选择通配符证书和多域名证书

随着互联网的发展&#xff0c;用户渐渐不再满足于只创建一个网站&#xff0c;因此&#xff0c;网站越来越多&#xff0c;管理多个网站的SSL证书的成本和时间也随之增加。为了节省管理多个站点的SSL证书的时间与成本&#xff0c;很多用户会选择通配符SSL证书与多域名SSL证书。这…

1.大数据概述

目录 概述hadoophadoop 模块hadoop 发行版apache社区版本CDP(CDHHDP)其它云产商框架选择 hadoop 安装 结束 概述 先了解几个常用的网站 apache 官网hadoop 官网hadoop githubhttps://github.com/apache/xxx [https://github.com/apache/spark (example)] hadoop hadoop 模块…