qiantianxianzi 2021-11-26 08:27 采纳率: 81.8%
浏览 152
已结题

运用python语言编写下面程序

问题遇到的现象和发生背景

编程实现一个函数isPrime(x),判断整数x是否为素数,是输出1,否则输出0
2、求出所有两位数的绝对素数的程序。
绝对素数:一个素数,当它的数字位置对换以后仍为素数,这样的数称为绝对素数。例如17和71都是素数,所以17和71是绝对素数
注意: 每一对绝对素数的输出格式为:17和71是绝对素数

3、 验证哥德巴赫猜想,即:任何一个大于或等于6的偶数,可以表示成两个素数之和。例如:11111112 = 11 + 11111101
定义函数Goldbach(N)将整数N分解成两素数之和以验证哥德巴赫猜想,你需要补充完整该函数代码。

问题相关代码,请勿粘贴截图

3定义一验证歌德巴赫猜想函数




```def Goldbach(N):  # 将N分解成两素数之和
    if N < 6 or N % 2 == 1:  # 若N小于6或N为奇数
        print('N应该是大于等于6的偶数')
    else:
        # 循环判断,得到符合要求的小于N的两个素数,并打印
        for x in range(2, N //2 + 1):  # 想想为什么是从2到N/2
            # 调用isPrime函数得到符合要求的小于N的两个素数
          ######## begin ###########
           
                
          ######## end ###########
                print(N, '=', x, '+', N - x)
                break
for num in [88, 68, 50, 1000]:
    Goldbach(num) 
print('*'*20)
```python


运行结果及报错内容
我的解答思路和尝试过的方法

def isPrime(int(x)):

if(x < 2):

    return 0;

for i in range(2,x) :

    if x % i == 0:
    
        return 0;
    

return 1;

x=eval(input())
y=(x%10)*10+x/10
result1=isPrime(x)
result2=isPrime(y)
print(result1,result2)

我想要达到的结果

展开全部

  • 写回答

1条回答 默认 最新

  • -Undefined_ 2021-11-26 08:31
    关注
    def isPrime(x):
        if x < 2:
            return 0
        for i in range(2, x):
            if x % i == 0:
                return 0
        return 1
    l=[]
    for x in range(10,100):
        y=(x%10)*10+x//10
        if x not in l and y not in l and x!=y and isPrime(x) and isPrime(y):
            print('%d和%d是绝对素数'%(x,y))
            l.append(x)
    
    def isPrime(x):
        if x < 2:
            return 0
        for i in range(2, x):
            if x % i == 0:
                return 0
        return 1
    def Goldbach(N):  # 将N分解成两素数之和
        if N < 6 or N % 2 == 1:  # 若N小于6或N为奇数
            print('N应该是大于等于6的偶数')
        else:
            # 循环判断,得到符合要求的小于N的两个素数,并打印
            for x in range(2, N // 2 + 1):  # 想想为什么是从2到N/2
                # 调用isPrime函数得到符合要求的小于N的两个素数
                ######## begin ###########
                if isPrime(x) and isPrime(N-x):
                ######## end ###########
                    print(N, '=', x, '+', N - x)
                    break
    
    
    for num in [88, 68, 50, 1000]:
        Goldbach(num)
    print('*' * 20)
    

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 12月3日
  • 已采纳回答 11月26日
  • 创建了问题 11月26日

悬赏问题

  • ¥15 Revit二次开发高程点标注问题
  • ¥15 两道题,用python写出代码
  • ¥15 charles打开Windows Proxy代理后电脑网络无法使用
  • ¥15 该怎么把前导 0 去掉存储给点思路
  • ¥15 智能循迹小车的红外模块无法给单片机输出信号或者是单片机无法输入信号,如何解决?(语言-c语言)
  • ¥15 slopBed分析过程中 genomesize中染色体命名与样本的sample_FE.bdg中的染色体命名方式不一致如何解决
  • ¥15 llama.cpp项目中为什么超过上下文窗口就报错
  • ¥15 基于stc89c52单片机的延时小夜灯
  • ¥15 VQAV2现在都是怎么做evaluation的啊
  • ¥20 C#添加、更新MYSQL数据库问题
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部