qq_36519547 2016-11-02 03:43 采纳率: 100%
浏览 1458
已采纳

C语言求解 一道素数的题目

从键盘输入一个整数,输出距离该数最近的素数。根据输入的数不同,此问题可能有一个答案(或者比输入的数大或者比输入的数小),也可能需要输出两个值(一个比输入的数大,一个比输入的数小,两个距离输入的数一样近)。PS:数学意义上的最小素数是2,例如,若输入-213,结果应是2
不要太高深 开头用#include int main for scanf printf 等等这几类基础的吧
其他复杂的就算了吧

  • 写回答

2条回答 默认 最新

  • AlbertS 博客专家认证 2016-11-02 04:17
    关注

    这就是基本的逻辑,这个也理解不了?自己改一下也行啊

     #include <stdio.h>
    #include <stdlib.h>
    
    int main()
    {
    
        int nMaxIntValue = 214783647;   // 这个是int的最大值
        int nDistance = nMaxIntValue;   // 保证距离最远
        int nInputValue = 0;
    
        printf("请输入一个整数:");
        scanf("%d", &nInputValue);
    
        if (nInputValue <= 2)
        {
            printf("结果是2\n");
        }
        else
        {
            int nFindCount = 0;
            int nRet1, nRet2;
    
            for(int nCurNumber = 3; nCurNumber <= nMaxIntValue; ++nCurNumber)
            {
                int nEndValue = nCurNumber / 2 + 1;
                bool bIsPrime = true;
                for (int nIndex = 2; nIndex <= nEndValue; ++nIndex)
                {
                    if (nCurNumber % nIndex == 0)
                    {
                        bIsPrime = false;
                        break;
                    }
                }
    
                // 是素数就进行距离判断
                if (bIsPrime)
                {
                    int nCurDistance = abs(nInputValue - nCurNumber);
                    if (nCurDistance < nDistance)
                    {
                        nDistance = nCurDistance;
                        nRet1 = nCurNumber;
                        nFindCount = 1;
                    }
                    else if (nCurDistance == nDistance)
                    {
                        nDistance = nCurDistance;
                        nRet2 = nCurNumber;
                        nFindCount = 2;
                        break;
                    }
                    else
                    {
                        break;
                    }
                }
            }
    
            if (nFindCount == 1)
            {
                printf("结果是%d\n", nRet1);
            }
            else if (nFindCount == 2)
            {
                printf("结果是%d %d\n", nRet1, nRet2);
            }
        }
    
    
        getchar();  // 就是为了看结果
        getchar();
    
    
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图