C++ spoj samer08e答错了

C++ spoj samer08e答错了,c++,algorithm,C++,Algorithm,以下是我对spoj问题的解决方案: 这是我的逻辑: 我检查给定的日期是否相邻。如果是,则添加成本差异。否则跳过 //header files omitted #define REP(i,n) for(int i=0; i<n; i++) #define FOR(i,st,end) for(int i=st;i<end;i++) int monthDates[] = {0,31,28,31,30,31,30,31,31,30,31,30,31}; bool isLeap( in

以下是我对spoj问题的解决方案:

这是我的逻辑:

我检查给定的日期是否相邻。如果是,则添加成本差异。否则跳过

//header files omitted

#define REP(i,n) for(int i=0; i<n; i++)
#define FOR(i,st,end) for(int i=st;i<end;i++)

int monthDates[] = {0,31,28,31,30,31,30,31,31,30,31,30,31};

bool isLeap( int y ){//check if year is leap
 if(y%4 == 0 && y%100 != 0 || y%400 == 0)
     return true;
return false;
}

bool checkAdjacent( int prev[], int curr[] ){//check if the dates are adjacent to each other
if( prev[0] == 31 && prev[1] == 12 && curr[0] == 1 && curr[1] == 1 && (curr[2] - prev[2]) == 1 )//last and first days of the year
    return true;
if( prev[2] == curr[2]){//same year
    if( prev[1] == curr[1]){//same month
        if((curr[0]-prev[0]) == 1)//same adjacent dates
            return true;
    }else if( curr[1] - prev[1] == 1){//adjacent months
        if( isLeap(prev[2]) && prev[1] == 2 && curr[1] == 3 && prev[0] == 29 && curr[0] == 1)//for leap year february
            return true;
        else if( !isLeap(prev[2]) && monthDates[prev[1]] == prev[0] && curr[0] == 1)
            return true;
    }
}
return false;
}


int main(){
int n;
while( scanf("%d", &n) && n){
    int prev[4], curr[4], count = 0;
    ll totalCost = 0;
    REP(i,4)
        scanf("%d", &prev[i]);
    FOR( i, 1, n){
        REP(j,4)
            scanf("%d", &curr[j]);
        if( checkAdjacent( prev, curr) ){
            totalCost += curr[3] - prev[3];
            count++;
        }
        prev[0] = curr[0];
        prev[1] = curr[1];
        prev[2] = curr[2];
        prev[3] = curr[3];
    }
    printf("%d %lld\n", count, totalCost);
}
return 0;
}
//省略了头文件

#定义的代表(i,n)(int i=0;i由于有两个人记录测量值,因此可能会在同一天记录两次,这可能会中断您的消费计算。

当年份为闰年,月份不是二月时,您的程序不会检查条件。添加此条件,您将获得AC。我希望这有帮助。

请包括所有代码,包括宏。混合and和ors,不带括号(就像在isLeap中一样)通常不是一个好主意。我检查了isLeap函数。它工作正常。“有时Martin这样做,有时Isa这样做。”没有明确排除两者都这样做的日期。在输入中指定它们将严格按递增顺序排列,并且没有两个日期是相同的。它说没有两个消耗量是相同的;它没有说明相邻日期。