qq_38574956 2017-06-26 03:38
浏览 1793

ACM题runtime error怎么解决

素数距离问题

时间限制:3000 ms | 内存限制:65535 KB

难度:2

描述

现在给出你一些数,要求你写出一个程序,输出这些整数相邻最近的素数,并输出其相距长度。如果左右有等距离长度素数,则输出左侧的值及相应距离。
如果输入的整数本身就是素数,则输出该素数本身,距离输出0

输入

第一行给出测试数据组数N(0<N<=10000)
接下来的N行每行有一个整数M(0<M<1000000),

输出

每行输出两个整数 A B.
其中A表示离相应测试数据最近的素数,B表示其间的距离。

样例输入

3
6
8
10

样例输出

5 1
7 1
11 1

#include "stdio.h"
int sushu(int x)
{
int i;
for(i=x-1; ;i--)
{
if(x%i==0)
{
return 0;
break;
}
if(i==2)
{
return 1;
break;
}
}
}
int main()
{
int a[10000];
int i,n,min,max,k;
scanf("%d",&n);
for(k=0;k {
scanf("%d",&a[k]);
}
for(k=0;k {
for(i=a[k]-1; ;i--)
{
if(sushu(i)==1)
{
min=i;
break;
}
if(sushu(i)==0)
continue;
}
for(i=a[k]+1; ;i++)
{
if(sushu(i)==1)
{
max=i;
break;
}
if(sushu(i)==0)
continue;
}
if(sushu(a[k])==1)
printf("%d %d\n",a[k],0);
else if(a[k]>(max+min)/2)
printf("%d %d\n",max,max-a[k]);
else
printf("%d %d\n",min,a[k]-min);
}
}

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 关于#python#的问题:求帮写python代码
    • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
    • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
    • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
    • ¥15 perl MISA分析p3_in脚本出错
    • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
    • ¥15 ubuntu虚拟机打包apk错误
    • ¥199 rust编程架构设计的方案 有偿
    • ¥15 回答4f系统的像差计算
    • ¥15 java如何提取出pdf里的文字?