目录

  • 单元1  初识Python
    • ● 任务 1.1  计算机程序设计语言概述
    • ● 任务 1.2 Python语言
    • ● 任务1.3 Python开发环境搭建
    • ● 任务 1.4 Python的简单使用
    • ● 知识拓展
    • ● 思考与练习
  • 单元2   Python基础知识
    • ● 任务2.1 Python程序基本结构
    • ● 任务2.2  标准输入输出
    • ● 任务2.3  Python对象
    • ● 任务2.4 Python变量
    • ● 任务2.5  数据类型
    • ● 任务2.6 字符串
    • ● 任务2.7 运算符
    • ● 知识拓展
    • ● 思考与练习
  • 单元3   程序流程控制
    • ● 任务3.1  顺序结构
    • ● 任务3.2 选择结构
    • ● 任务3.3  循环结构
    • ● 知识拓展
    • ● 思考与练习
  • 单元4  Python序列
    • ● 任务4.1  序列
    • ● 任务4.2 列表
    • ● 任务4.3  用于序列操作的常用内置函数
    • ● 任务4.4   元组
    • ● 任务4.5  字典
    • ● 任务4.6  集合
    • ● 知识拓展
    • ● 思考与练习
  • 单元5  函数
    • ● 任务5.1 函数的定义与调用
    • ● 任务5.2 函数的参数
    • ● 任务5.3   参数类型
    • ● 任务5.4  变量作用域
    • ● 任务5.5   嵌套调用与递归调用
    • ● 任务5.6  lambda表达式
    • ● 任务5.7  模块
    • ● 知识拓展
    • ● 思考与练习
  • 单元6  异常处理
    • ● 任务6.1 异常处理的基本概念
    • ● 任务6.2 Python的异常处理语句
    • ● 任务6.3  自定义异常
    • ● 知识扩展
    • ● 思考与练习
  • 单元7  文件操作
    • ● 任务7.1  文件的分类
    • ● 任务7.2  文件对象
    • ● 任务7.3  文本文件
    • ● 任务7.4  二进制文件
    • ● 知识拓展
    • ● 思考与练习
  • 单元8  面向对象程序设计
    • ● 任务8.1 面向对象技术的基本概念
    • ● 任务8.2 类与对象
    • ● 任务8.3 类的继承
    • ● 任务8.4 方法重写
    • ● 知识扩展
    • ● 思考与练习
  • 单元9  网络编程基础
    • ● 任务9.1  Socket概述
    • ● 任务9.2   Socket对象内建方法
    • ● 任务9.3  Socket编程实例
    • ● 任务9.4    PythonInternet模块
    • ● 知识扩展
    • ● 思考与练习
  • 单元10    Python标准库及第三方库
    • ● 任务10.1 Python标准库
    • ● 任务10.2 Python第三方库的下载及安装
    • ● 任务10.3  Python第三方库举例
    • ● 知识扩展
    • ● 思考与练习
  • 任务11 用户图形界面(GUI)
    • ● 任务11.1 图形用户界面概述
    • ● 任务11.2 窗体容器和组件
    • ● 任务11.3 界面布局管理
    • ● 任务11.4 文本框组件
    • ● 任务11.5 其他组件
    • ● 任务11.6菜单与对话框
    • ● 任务11.7 鼠标键盘事件
    • ● 知识扩展
    • ● 思考与练习
  • 任务12   Python操作数据库
    • ● 数据库基础
    • ● 结构化查询语言SQL
    • ● Python操作数据库核心API
    • ● Python操作数据库案例
    • ● sqlite3 实训练习案例
    • ● pymysql 数据库实训案例
    • ● 小结  思考与练习
  • 习题解析(线上作业等参考解答)
    • ● 第一单元 初识Python  作业
    • ● 第二单元  Python基础(作业)
    • ● 第三单元  程序流程控制 作业(1)
    • ● 第三单元  程序流程控制  作业(2)
    • ● 第四单元  Python序列   作业
    • ● 第五单元   函数   作业
    • ● 单元六  异常处理  作业
    • ● 单元七、八  文件操作,GUI,面向对象
    • ● 单元九   网络编程基础
    • ● 线上习题解析
    • ● 编程训练
  • 应用题解(综合编程技术)
    • ● 《食品识别小专家》
    • ● 格式输出
    • ● 习题选解
    • ● 每日一帖
    • ● 模拟基本信息
    • ● 模拟基本数据
    • ● 数制转换
    • ● 定制每日运动计划
    • ● 《简易购物系统》
  • 课程章节测验
    • ● 第1次章节测验
  • 复习
    • ● Python基础知识总结
  • 第三方库TOOLS(备用)
    • ● 库模块(可下载)
    • ● 供考查备用的库模块(可下载)
思考与练习

项目实践 验证哥德巴赫猜想

1742年6月,德国著名的数学家哥德巴赫(C.Goldbah 1690-1764)预言“任何一个6以上的偶数都可以分解为两个素数的和”, 这就是著名的哥德巴赫猜想,俗称“1+1=2”。例如6=3+3,8=5+3,10=5+5…等,这个问题得到千千万万个数的验试,但至今未得到数学证明。

1742年6月,德国著名的数学家哥德巴赫(C.Goldbah 1690-1764)预言

“任何一个6以上的偶数都可以分解为两个素数的和”

 这就是著名的哥德巴赫猜想,俗称“1+1=2”,例如

6=3+3

8=5+3

10=5+5

一个偶数分解成两个素数的和的分解不是唯一的,例如

24=5+19

24=17+7

这个问题得到千千万万个数的验试,但至今未得到数学证明。

解决思想:

对于任意一个偶数n,问题是要找到一个比n小的素数p ,使q=n-p也为素数,这样n 便分解为p与q=n-p 两个素数之和。

显然n=p+q可以假定p<=n/2,设置maxp=n//2

构造p=1,3,5,....,maxp的循环,判断p是否时素数

如果不是就p=p+2换下一个p再继续

如果p是素数,就判断q=n-p是否时素数,如果不是就继续p=p+2的下一个p测试

如果q也是素数,于是就找到一个分解n=p+q,其中p,q都是素数。

#输入偶数,如果不满足要求就继续输入

while True:

    n=input("输入6以上的偶数:")

    n=int(n)

    if n%2==0 and n>=6:

        break

#p的最大值maxp

maxp=n//2

p=1

while p<=maxp:

    #判断p是否是素数,flag=True表示是素数

    flag=True

    for k in range(2,p):

        if p%k==0:

            #p可以被比它小的整数除尽,不是素数

            flag=False

            break

    #如果p是素数,再次判断q是否时素数

    if flag:

        q=n-p

        for k in range(2,q):

            if q %k==0:

                # q可以被比它小的整数除尽,不是素数

                flag=False

                break

        #q也是素数,得到一个分解n=p+q

        if flag:

            print(n,"=",p,"+",q)

    p=p+2

print("done!")