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 visual studio2022中文乱码无法解决
    • ¥15 关于华为5g模块mh5000-31接线问题
    • ¥15 keil L6007U报错
    • ¥15 webapi 发布到iis后无法访问
    • ¥15 初学者如何快速上手学习stm32?
    • ¥15 如何自动更换布娃娃图片上的衣服
    • ¥15 心理学eprime编程
    • ¥15 arduino esp8266开发
    • ¥15 stm32单片机通过485发送命令给驱动器控制电机转动,同样的代码f103可以控制电机转动,换到f407不能动了,但是用串口助手调试407显示发送的命令都是正确的,卡了好久了这是发送规则
    • ¥15 stm32f103c8t6最小系统板+2.8寸TFTLCD板子