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