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 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试,帮帮忙吧
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建