素数距离题目

来源:互联网 发布:mac xlsx文件怎么打开 编辑:程序博客网 时间:2024/06/14 06:07

好久没有刷题了,于是去南阳理工的oj上从刷入门题,练练手,题目如下:

素数距离问题

时间限制:3000 ms  |  内存限制:65535 KB
难度:2
描述
现在给出你一些数,要求你写出一个程序,输出这些整数相邻最近的素数,并输出其相距长度。如果左右有等距离长度素数,则输出左侧的值及相应距离。
如果输入的整数本身就是素数,则输出该素数本身,距离输出0
输入
第一行给出测试数据组数N(0<N<=10000)
接下来的N行每行有一个整数M(0<M<1000000),
输出
每行输出两个整数 A B.
其中A表示离相应测试数据最近的素数,B表示其间的距离。
样例输入
36810
样例输出
5 17 111 1
#include <stdio.h>#include <math.h>int isprime(int n){int flag = 0;for(int j = 2; j <= sqrt(n); j++){if(n % j == 0)flag = 1;}return flag;}int main(){int N, M, L1, L2=2, f1, f2;scanf("%d",&N);while(N--){scanf("%d",&M);if(M ==1 ){printf("%d %d\n", 2, 1);continue;}for(int i = M; i > 1; i--){if(isprime(i) == 0){L1 = i;break; }}for(int j = M; ; j++){if(isprime(j) == 0){L2 = j;break; }}if(M-L1 > L2-M)printf("%d %d\n", L2, L2-M);elseprintf("%d %d\n", L1, M-L1);}return 0;}
一定要注意输入1的时候,特殊处理 ,这道题通过只有24%,搞不好,很多人就是第一次忘记对1的处理。我也看过该题的最优代码,能写出最优代码的人是对for循环理解的相当透彻的,for(int  i=M;isprime(i);i++)for(int  j=M;isprime(M);j--).

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 解压包文件数据损坏该怎么办 电脑被压缩后电脑打不开怎么办 眼睛里进了飞虫怎么办 虫子飞到眼睛里怎么办 云电脑pc版双鼠标怎么办 电脑蓝屏代码7f怎么办 笔记本电脑蓝屏开不了机怎么办 装xp系统后蓝屏怎么办 一键ghost断电了怎么办 如何防止cpu降频怎么办 win7 64位系统不兼容怎么办 网页无法加载打印机插件怎么办 微信提示安装了插件怎么办 电脑上不了网怎么办 win10 win10电脑突然没网了怎么办 笔记本玩战争前线发热严重怎么办 玩战争前线总是闪退怎么办 uu加速器卡在29怎么办 新ipad下载不了东西怎么办 福昕pdf阅读器找不到图章怎么办 战地4没达到分数怎么办 植物在太暗环境怎么办 玩绝地求生机型不支持怎么办 安卓安装包损坏怎么办 方舟手游安装包损坏怎么办 7p新机耗电快怎么办 不小心把图片删了怎么办 腿上毛又长又多怎么办 征兵体检体重太轻怎么办 体检发现颈部有淋巴节怎么办? 4岁宝宝汗毛重怎么办 嘴巴张开闭不上怎么办 口张开闭不上怎么办 要去当兵有痔疮怎么办 狗舔的东西吃了怎么办 婚检说生过孩子怎么办 劳动法规定身体有疾病的怎么办 铁路对职工醉驾怎么办 入职体检高血糖怎么办 睾丸捏一下很疼怎么办 小孩睾丸受外力红肿该怎么办