qq_36519547 2016-11-02 02:13 采纳率: 100%
浏览 1029
已采纳

C语言新手问题求解答!!

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

  • 写回答

3条回答 默认 最新

  • AlbertS 博客专家认证 2016-11-02 03:06
    关注

    这代码你先试试吧,可以简化的,怕你接受不了,先看看这个能不能理解

    #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");
            getchar();  // 就是为了看结果
            getchar();
            return 0;
        }
    
    
        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;
    } 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥100 有人会搭建GPT-J-6B框架吗?有偿
  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名