项目Euler 19:计算星期日,Java

时间:2016-02-03 06:27:45

标签: java calendar dayofweek

我使用Java的Calendar API来计算每个月第一天的星期日总数。 以下代码为指定的开始日期和日期格式的结束日期(年/月/日)提供了额外的一天。 1900/01/01至1910/01/01

代码的输入格式为:
1·=测试用例< = 10个
开始日期
截止日期

import java.io.*;
import java.util.*;
import java.time.DayOfWeek;
public class ProjectEuler19 {

public static void main(String[] args) {
    /* Enter your code here. Read input from STDIN. Print output to STDOUT. Your class should be named Solution. */
    Scanner scanner = new Scanner(System.in);
    int testCases = scanner.nextInt();
    do{
     int sundays = 0;
     Calendar c = Calendar.getInstance();
     int monthStart,dateStart,monthEnd,dateEnd;
     int yearStart,yearEnd;
     yearStart = scanner.nextInt();
     monthStart = scanner.nextInt();
     dateStart = scanner.nextInt();
     yearEnd = scanner.nextInt();
     monthEnd = scanner.nextInt();
     dateEnd = scanner.nextInt();
     String[] getDayOfWeek = new String[]{
        "MONDAY",
        "TUESDAY",
        "WEDNESDAY",
        "THURSDAY",
        "FRIDAY",
        "SATURDAY",
        "SUNDAY"
     };
        for(int y = yearStart; y<=yearEnd; y++) {
                for(int m = monthStart; m<=12; m++) {
                        c.set(y,m-1,1);
                        if(String.valueOf(getDayOfWeek[c.get(Calendar.DAY_OF_WEEK)-1]).equals(String.valueOf(DayOfWeek.SUNDAY))) {
                            sundays++;
                        }
                        if(m > monthEnd && y == yearEnd)
                            break;
                }
        }
        System.out.println(sundays);
       testCases--;
    }while(testCases != 0 && testCases>=1 && testCases<=100);

  }
}

出来的样品是:

2
1900 1 1
1910 1 1
17
2000 1 1
2020 1 1
36

根据日历,1900年至1910年之间的星期日数为18,2000年至2010年的星期日数为35日。

1 个答案:

答案 0 :(得分:1)

你实际上是在计算星期一的数量。 Calendar.SUNDAY是第一个星期日常量,值为1.

为什么不直接将c.get(Calendar.DAY_OF_WEEK)与Calendar.SUNDAY进行比较?