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 js调用html页面需要隐藏某个按钮
    • ¥15 ads仿真结果在圆图上是怎么读数的
    • ¥20 Cotex M3的调试和程序执行方式是什么样的?
    • ¥20 java项目连接sqlserver时报ssl相关错误
    • ¥15 一道python难题3
    • ¥15 牛顿斯科特系数表表示
    • ¥15 arduino 步进电机
    • ¥20 程序进入HardFault_Handler
    • ¥15 oracle集群安装出bug
    • ¥15 关于#python#的问题:自动化测试