| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 830 人关注过本帖
标题:程序还是错的,求大家指点下
只看楼主 加入收藏
红糖水
Rank: 2
等 级:论坛游民
帖 子:42
专家分:11
注 册:2013-2-3
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:13 
程序还是错的,求大家指点下

题目24
题目信息运行结果本题排行讨论区素数距离问题
时间限制: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>
#include<math.h>
int main()
{
    long sushu(long i);
    long n,m,a,b,i,j,t1,t2,p1,p2;
    scanf("%d",&n);
    while(n--)
    {
        scanf("%d",&m);
        if(m>=2)
     {
        for(i=m;i>0;i--)
        {
            if(sushu(i))
            {t1=i;break;}
        }
        t2=m-t1;
        for(i=m;;i++)
        {
            if(sushu(i))
            {p1=i;break;}
        }
        p2=p1-m;
        if(t2<=p2)
        printf("%d %d\n",t1,t2);
        else
        printf("%d %d\n",p1,p2);
     }
     else
     printf("2 0\n");
    }
}
long sushu(long i)
{
    int j,temp;
    if(i<2)
    return 0;
    else
{
    temp=(int)sqrt(i);
    for(j=2;j<=temp;j++)
 {
    if(i%j==0)
    {break;}
 }
    if(j>temp)
    {return 1;}
    else
    return 0;
}
}

搜索更多相关主题的帖子: 讨论区 
2013-04-02 17:07
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
记得我跟你说过要优化算法,你不听,这样子估计还是时间超出限制了吧,不多说,链接在你上一个帖子里,好好看看吧


[fly]存在即是合理[/fly]
2013-04-02 17:17
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:3 
ACM对时间的要求非常苛刻,所以要注意优化

Maybe
2013-04-02 17:50
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:0 
为什么现在一堆语法都弄不清楚的人这么喜欢钻研ACM???

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-04-02 17:54
simple9527
Rank: 1
等 级:新手上路
帖 子:3
专家分:1
注 册:2013-3-3
收藏
得分:1 
学习了。。。
2013-04-02 20:32
面朝大海1994
Rank: 2
等 级:论坛游民
威 望:1
帖 子:27
专家分:38
注 册:2012-12-31
收藏
得分:2 
程序要优化了,不要以时间为代价换空间。

吃得苦中苦,方为人上人!
2013-04-03 08:11
红糖水
Rank: 2
等 级:论坛游民
帖 子:42
专家分:11
注 册:2013-2-3
收藏
得分:0 
回复 2楼 azzbcc
时间没有超出,我优化了,但还是有错误
2013-04-03 14:17
红糖水
Rank: 2
等 级:论坛游民
帖 子:42
专家分:11
注 册:2013-2-3
收藏
得分:0 
回复 4楼 peach5460
貌似我没有出现语法错误吧?
2013-04-03 14:18
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:5 
以下是引用红糖水在2013-4-3 14:17:22的发言:

时间没有超出,我优化了,但还是有错误

你把 输入 1的结果改好再看看、、、


[fly]存在即是合理[/fly]
2013-04-03 15:15
红糖水
Rank: 2
等 级:论坛游民
帖 子:42
专家分:11
注 册:2013-2-3
收藏
得分:0 
回复 9楼 azzbcc
1不是素数啊,输入1输出2 0,错了吗?
2013-04-04 16:15
快速回复:程序还是错的,求大家指点下
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.013095 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved