冲冲拳 2022-08-15 22:43 采纳率: 100%
浏览 73
已结题

素数对猜想测试点问题

PTA 1007素数对猜想

img

代码

#include<stdio.h>
#include<math.h>
int FindSu(int n) {
int i;
int flag = 0 ;
for (i = 2; i <= sqrt(n); i++) {
if (n % i == 0) {
flag = 1; //flag=1表示不是素数
}
if ((i > n / 2) && (n != 1)) flag = 0;
}
return flag;
}
int main() {
int n;
int times = 0;
scanf_s("%d", &n);
int i;
for (i = 3 ; i <= n; i++) {
if (FindSu(i) == 0) {
if (FindSu(i) == FindSu(i + 2)) {
times++;
i++;
}
}
}
printf("%d", times);
return 0;
}

运行结果及报错内容

img

我的解答思路和尝试过的方法

思路:不采用先计算素数表,采用一边判断x是不是素数,一边判断x+2是不是素数。如果两者都是素数,则计数器+1。
我已经解决的问题:"不超过“和”不超时“。
我在网上找过了其他c语言代码,自己输入随机数进行对比,答案结果一致。

我想要达到的结果

测试点134。
感谢帮助!

  • 写回答

3条回答 默认 最新

  • qzjhjxj 2022-08-15 23:27
    关注

    修改见注释,供参考:

    #include<stdio.h>
    //#include<math.h> 修改
    int FindSu(int n) {
        int i;
        int flag = 0 ;
        if (n <= 1) return 1;  //修改
        for (i = 2; i * i <= n; i++) {
            if (n % i == 0) {
                flag = 1; //flag=1表示不是素数
                break;
            }
            //if ((i > n / 2) && (n != 1)) flag = 0; 修改
        }
        return flag;
    }
    int main() {
        int n;
        int times = 0;
        scanf("%d", &n);
        int i;
        for (i = 3 ; i < n - 1; i++) {  //for (i = 3 ; i <= n; i++) 修改
            if (FindSu(i) == 0 && FindSu(i + 2) == 0) {
               //if (FindSu(i) == FindSu(i + 2)) {  修改
                   times++;
                   //i++;    修改
               //}           修改
            }
        }
        printf("%d", times);
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 8月24日
  • 已采纳回答 8月16日
  • 创建了问题 8月15日

悬赏问题

  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题