lz无痕 2017-07-16 09:34 采纳率: 40%
浏览 821

求解,(不要用数组)。。。。

将大于整数m且紧靠m的k个素数输出。列如,若m的值为17,k的值为5,则应输出19,23,29,31,37。m和k的值从键盘输入。

  • 写回答

5条回答 默认 最新

  • shifenglv 2017-07-16 12:11
    关注

    #include
    #include

    int main()
    {
    int m, k;

    scanf_s("%d%d", &m, &k);
    
    //从m+1开始枚举,寻找与m最近的素数
    for (int i = m + 1;k>0 ;i++)
    {
        int n = (int)sqrt(i);//一个合数的最小约数不会超过它本身的开方(1 除外)
        int j;
    
        //判断一个数是不是素数
        for (j = 2;j <= n;j++)
        {
            if (i%j == 0)break;//一旦能整除,就是合数,结束循环
        }
    
        //如果j>n,说明上一个for循环没有中断,也就是说从2到它本身的开方n之间没有约数,因此这个数i是素数。
        if (j >n) {
            printf("%d\n", i);
            k--;
        }
    
    }
    

    }

    
    
    评论

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)