| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1006 人关注过本帖
标题:连一道求素数的题目都做不对(┬_┬)
只看楼主 加入收藏
qq731574722
Rank: 1
等 级:新手上路
帖 子:10
专家分:7
注 册:2016-2-3
结帖率:100%
收藏
已结贴  问题点数:5 回复次数:1 
连一道求素数的题目都做不对(┬_┬)
Description

请判断给出的n是不是素数?

Input

输入每一行包含一个正整数n,n<=231-1;      (2的三十一次方)

Output

如果n是素数请输出“YES”,否则输出“NO”;

Sample Input

4
5
6

Sample Output

NO
YES
NO
程序代码:
#include <stdio.h>

 
int main()
{
    int n,i,flag;
    while(scanf("%d",&n)!=EOF)
    {
        if(n<=0)
            break;
        flag=1;
        for(i=2;i<=n/2;i++)
            if(n%i==0)
                flag=0;
        if(flag==1&&n>1)
            printf("YES\n");
        else
            printf("NO\n");
    }
    return 0;
}
/**************************************************************
    Problem: 1012
    User: 201501020151
    Language: C
    Result: Time Limit Exceed
****************************************************************/

结果上面写着,时间超限,我真是不懂了,完全就是按老师的思路写的怎么会不对呢?
http://acm.zcmu.这是网址。

[此贴子已经被作者于2016-2-4 03:08编辑过]

搜索更多相关主题的帖子: 正整数 
2016-02-04 03:06
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9024
专家分:54030
注 册:2011-1-18
收藏
得分:5 
首先,这个算法本身就不快
其次,你这个算法还可以优化
for(i=2;i<=n/2;i++),其中 n/2 可优化为 根号n
对于2的倍数,没必要每个都除一下
2016-02-04 08:29
快速回复:连一道求素数的题目都做不对(┬_┬)
数据加载中...
 
   



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

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