TPIO 2020-12-25 10:21 采纳率: 100%
浏览 67
已采纳

求助C语言 把一个6以上的偶数分解成两个素数,为什么程序不对

为什么分解结果里第一个数字z会有5的倍数

  • 写回答

4条回答 默认 最新

  • qq_25376897 2020-12-25 11:38
    关注
    #include <stdio.h>
    #include <math.h>
    
    int f(int n) //判断n是否为素数
    {
        if(n<=1){
            return 0;
        }
        
        int k = sqrt(n);
        for(int i=2;i<=k;i++){
            if(n%i==0){
                return 0;
            }
        }
        
        return 1;
    }
    
    int main(void)
    {
    	int n;
    	scanf("%d",&n);
    	for(int i=2;i<n;i++){
    	    if(f(i)&&f(n-i)){
    	        printf("%d-%d",i,n-i);
    	        return 0;
    	    }
    	}
    	return 0;
    }
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器