加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

在C中查找是否为Prime的数字

发布时间:2020-12-16 10:35:58 所属栏目:百科 来源:网络整理
导读:我正在编写一个C程序来查找数字是否为素数.每当我运行它并输入一个数字时,输入的值就会改变.请指出漏洞. #includestdio.h#includeconio.hint main(){ int x; int y; y=getchar(); for(x=2;xy;++x){ if(y%x != 0 y!=x) printf(" THE NUMBER %d is A PRIME n"
我正在编写一个C程序来查找数字是否为素数.每当我运行它并输入一个数字时,输入的值就会改变.请指出漏洞.

#include<stdio.h>
#include<conio.h>
int main()
{

    int x;
    int y;
    y=getchar();
    for(x=2;x<y;++x){
       if(y%x != 0 && y!=x)
            printf(" THE NUMBER %d is  A  PRIME n",y);
        else
            printf(" r THE NUMBER %d IS NOT A PRIME",y);
            break;
    }
}

我使用Code :: Blocks IDE和GCC Compiler

解决方法

顾名思义,getchar()从标准输入中获取单个字符.例如,如果输入3,y将获得字符“3”的ASCII代码,这显然不是您想要的.

试试scanf:

scanf("%d",&y);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读