冻鸦2345 2021-10-30 20:31 采纳率: 82.6%
浏览 50
已结题

c语言洛谷P1217 [USACO1.5]回文质数 Prime Palindromes ,看下哪里错了

为什么我这样写函数直接跳出


#include<stdio.h>
#include<math.h>
int z(int i){
    for(int o=2;o<=floor(sqrt(i)+0.5);o++){
        if(i%o==0)return 0;
    }
    return 1;
}
int h(int i){
    if(i==5&&i==7)return 1;
    else if(101<=i&&i<=999&&(i%100==i/10))return 1;
    else if(10001<=i&&i<=99999&&(i/10000==i%100000))return 1;
    else if(1000001<=i&&i<=9989899&&(i%10000000==i/1000000))return 1;
    return 0;
}


int main(){
    int a,b;
    scanf("%d %d",&a,&b);
    for(int i=a;i<=b;i++){
        if(z(i)==1&&(h(i)==1)){    
            printf("%d\n",i);
        }
    }
    return 0;
}
  • 写回答

1条回答 默认 最新

  • qzjhjxj 2021-10-31 00:33
    关注

    int h(int i) 回文数判断函数存在问题,比如101,i%100 == i/10 ,101%100 = 01=1, 101/10 = 10,两者不等,回文数判断函数建议用下面这种:

    int is_huiwen(int p) {
        int ans, temp;
        temp = p;
        ans = 0;
        while (temp) {
            ans = ans * 10 + temp % 10;
            temp /= 10; 
        }
        if(ans == p)
            return 1;
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月8日
  • 已采纳回答 10月31日
  • 创建了问题 10月30日

悬赏问题

  • ¥15 在虚拟机中安装flash code
  • ¥15 单片机stm32f10x编写光敏电阻调节3.3伏大功率灯亮度(光强越大灯越暗,白天正常光强灯不亮,使用ADC,PWM等模块)望各位找一下错误或者提供一个可实现功能的代码
  • ¥20 verilog状态机方法流水灯
  • ¥15 pandas代码实现不了意图
  • ¥15 GD32H7 从存储器到外设SPI传输数据无法重复启用DMA
  • ¥25 LT码在高斯信道下的误码率仿真
  • ¥45 渲染完成之后将物体的材质贴图改变,自动化进行这个操作
  • ¥15 yolov5目标检测并显示目标出现的时间或视频帧
  • ¥15 电视版的优酷可以设置电影连续播放吗?
  • ¥50 复现论文;matlab代码编写