首页 > 其他 > 详细

POJ 3292

时间:2016-01-25 22:49:05      阅读:212      评论:0      收藏:0      [点我收藏+]

这题跪了一下午、、都不知道自己怎么错的、、先贴个正确的代码

这题有坑、

#include <iostream>
#include <math.h>
#include <stdio.h>
#include <string.h>
#include <queue>
#include <algorithm>
#include <math.h>
#define INF 0x3f3f3f3f
using namespace std;

int has[1000002];
int main()
{
    int h;
    memset(has,0,sizeof(has));
    for(int i=5; i<=1000001; i+=4)
    {
        for(int j=5; j<=1000001; j+=4)
        {
            h=i*j;
            if(h>1000001)
            {
                break;
            }
            if( has[i]==0 && has[j]==0)
            {
                has[h]=1;
            }
            else
            {
                has[h]=-1;
            }
        }
    }
    int sum=0;
    int pri[1000002];
    for(int i=1;i<=1000001;i++)
    {
        if(has[i]==1)
        {
            sum++;
        }
        pri[i]=sum;
    }
    int n;
    while(~scanf("%d",&n)&&n)
    {
        printf("%d %d\n",n,pri[n]);
    }
    return 0;
}

 

POJ 3292

原文:http://www.cnblogs.com/qioalu/p/5158760.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!