从键盘输入一个整数,输出距离该数最近的素数。根据输入的数不同,此问题可能有一个答案(或者比输入的数大或者比输入的数小),也可能需要输出两个值(一个比输入的数大,一个比输入的数小,两个距离输入的数一样近)。PS:数学意义上的最小素数是2,例如,若输入-213,结果应是2
不要太高深 开头用#include int main for scanf printf 等等这几类基础的吧
其他复杂的就算了吧
C语言新手问题求解答!!
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
关注 这代码你先试试吧,可以简化的,怕你接受不了,先看看这个能不能理解
#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; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥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系统签名