zoj3326 An Awful Problem

题目大意:求规定时间范围内,月和日(例如:2月3号)都为素数的日期一共有多少, 考虑边界。
这就一模拟,考虑的细一点应该就可以。 只要一出大意了就会无限wrong!! 也没什么算法,直接上代码吧.

#include<iostream>
#include<cstdio>
using namespace std;

int isprime(int x)
{
    if(x < 2) return 0;
    for(int i = 2; i <= sqrt(x); i++)
        if(x % i == 0)
        return 0;
    return 1;
}
int main()
{
    int t, a[40], m[20];
    memset(a, 0, sizeof(a));
    memset(m, 0, sizeof(m));
    //这个a[i]存储的是1到i天中, 共有几个天时素数。
    for(int i = 1; i <= 31; i++)
    {
        if(isprime(i) == 1)
            a[i] = a[i-1] + 1;
        else
            a[i] = a[i-1];
    }
    //m[i]存储的是:前i个月(包含i月)非闰年时, 共有多少个日期是月、号都为素数。
    for(int i = 1; i <= 12; i++)
    {
        if(i == 3 || i == 5 || i == 7)
            m[i] = m[i-1] + 11;
        else if(i == 11)
            m[i] = m[i-1] + 10;
        else if(i == 2)
            m[i] = m[i-1] + 9;
        else
            m[i] = m[i-1];
    }
    cin >> t;
    while(t--)
    {
        int y1, m1, d1, y2, m2, d2;
        cin >> y1 >> m1 >> d1 >> y2 >> m2 >> d2;
        int sum = 0;
        for(int i = y1; i < y2; i++)//此处把y1到y2-1年所有符合的日期计算出来
        {
            sum += m[12];
            if(i % 400 == 0 || (i % 4 == 0 && i % 100 != 0))
                sum += 1;
        }
        //下面这部分是减去y1年多算的
        sum = sum - m[m1-1];
        if(y1 % 400 == 0 || (y1 % 4 == 0 && y1 % 100 != 0))
        {
            if(m1 > 2)
                sum--;
        }
        if(isprime(m1))
            sum = sum - a[d1-1];
        //下面这部分是加上y2年没算的
        sum = sum + m[m2-1];
        if(y2 % 400 == 0 || (y2 % 4 == 0 && y2 % 100 != 0))
        {
            if(m2 > 2)
                sum++;
        }
        if(isprime(m2))
            sum = sum + a[d2];
        printf("%d\n", sum);
    }
    return 0;
}

你可能感兴趣的:(模拟,ZOJ3326)