| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1167 人关注过本帖
标题:这题有会做的吗,我做总是超时,谁有更好的办法,求指教
只看楼主 加入收藏
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
结帖率:87.5%
收藏
已结贴  问题点数:10 回复次数:19 
这题有会做的吗,我做总是超时,谁有更好的办法,求指教
Please calculate how many prime numbers are there between two integers a and b (including).




Input
There are some cases. Each line of input a b. 1 ≤ a < b ≤ 10000.



Output
If the result is a prime number, output "YES", else output "NO" in a single line.



Sample Input
1 3
5 9
1 1000


Sample Output
YES
YES
NO
搜索更多相关主题的帖子: including between numbers result single 
2015-03-17 09:28
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
收藏
得分:0 
是天大acm第4088题
2015-03-17 09:29
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
1到1万也就1千多个质数,先全部取出存到数组中。

这样就会快很多了


[fly]存在即是合理[/fly]
2015-03-17 09:31
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
收藏
得分:0 
我后来也是这么想的,但不知怎么做,这是我的代码,会超时

#include <iostream>
#include <stdio.h>
using namespace std;

bool isPrime(unsigned long n) {  
    if (n <= 3) {      
        return n > 1;  
    } else if (n % 2 == 0 || n % 3 == 0) {   
        return false;   
    } else {     
        for (unsigned short i = 5; i * i <= n; i += 6) {      
            if (n % i == 0 || n % (i + 2) == 0) {      
                return false;      
            }      
        }     
        return true;  
    }
}
int main(){
   
     int a[1299],i,t=0;
    for(i=2;i<10000;i++){
        if(isPrime(i)){
            a[t]=i;
            t++;
        }
    }
    int c,b,min=0,max=0;
   
    while(true){
        scanf_s("%d %d",&b,&c);
        for(i=0;i<1299;i++){
            if(i==0){
                if(a[0]>=b){
                    min=0;
  //                  cout<<"min1"<<min<<endl;
                }
            }

            if(i>=1){
                if(a[i]>=b&&a[i-1]<=b){
 //                   cout<<"min2"<<min<<endl;
                    min=i;
                }
                if(a[i]>=c&&a[i-1]<=c){

                    max=i;
  //                  cout<<"max"<<max<<endl;
                     break;
                }
            }

        }


        if((max-min)==1){
            cout<<"YES"<<endl;
        }
        if((max-min)!=1){
            cout<<"NO"<<endl;
        }
        
    }


    return 0;
}
2015-03-17 09:49
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
收藏
得分:0 
回复 3楼 azzbcc
你帮我看下代码怎么改
2015-03-17 10:12
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
不到1300次的循环也超时!


[fly]存在即是合理[/fly]
2015-03-17 10:35
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
收藏
得分:0 
回复 6楼 azzbcc
不知,反正超时,估计是求素数的数组用了太多时间
2015-03-17 10:48
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
收藏
得分:0 
回复 6楼 azzbcc
也可能不能这么写,我也是没办法了
2015-03-17 10:49
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
进去看了一下,Time Limit: 1.0 Seconds

再优化吧!

质数表加上二分查找

我这WA,待我先查查


[fly]存在即是合理[/fly]
2015-03-17 11:16
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
AC了,你加油


[fly]存在即是合理[/fly]
2015-03-17 13:17
快速回复:这题有会做的吗,我做总是超时,谁有更好的办法,求指教
数据加载中...
 
   



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

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