我最近编写了一个程序,计算1900年后第十三个星期五的数量。代码非常好,它的工作原理;然而,有些部分是非常冗余的。无论如何,我可以简化它。如何简化我的代码?
import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
public class friday {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new FileReader("friday.in"));
PrintWriter pw= new PrintWriter(new FileWriter("friday.out"));
int years = Integer.parseInt(br.readLine());
int saturday = 0;
int sunday = 0;
int monday = 0;
int tuesday = 0;
int wedensday = 0;
int thursday = 0;
int friday = 0;
int month = 1;
int day = 1;
int months = 12*years;
int test = 0;
int year = 1900;
for(int i = 0; i < months; i++)
{
if ((year % 4 == 0) && year % 100 != 0)
{
test = 1;
}
else if ((year % 4 == 0) && (year % 100 == 0) && (year % 400 == 0))
{
test = 1;
}
else
{
test = 0;
}
if(month == 1)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 3) % 7;
}
if(month == 2)
{
if(test == 1)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
//leapyear = 1;
day = (day + 1) % 7;
}
else
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 0) % 7;
//leapyear++;
}
}
if(month == 3)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 3) % 7;
}
if(month == 4)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 2) % 7;
}
if(month == 5)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 3) % 7;
}
if(month == 6)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 2) % 7;
}
if(month == 7)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 3) % 7;
}
if(month == 8)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 3) % 7;
}
if(month == 9)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 2) % 7;
}
if(month == 10)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 3) % 7;
}
if(month == 11)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 2) % 7;
}
if(month == 0)
{
if(day == 1)
{
saturday++;
}
if(day == 2)
{
sunday++;
}
if(day == 3)
{
monday++;
}
if(day == 4)
{
tuesday++;
}
if(day == 5)
{
wedensday++;
}
if(day == 6)
{
thursday++;
}
if(day == 0)
{
friday++;
}
day = (day + 3) % 7;
year++;
}
month = (month + 1) % 12;
}
pw.println(saturday + " " + sunday + " " + monday + " " + tuesday + " " + wedensday+ " " + thursday + " " + friday);
pw.close();
//System.out.println(saturday + " " + sunday + " " + monday + " " + tuesday + " " + wedensday+ " " + thursday + " " + friday);
}
}
如果您有功能代码,http://www.codereview.stackexchange.com是更适合此问题的地方。 – CubeJockey
你知道数组吗?有些东西告诉我它可能会有用。或枚举 – Dici
**来自Parttimereaper的评论:** 那么我可能会使用switch语句来提高可读性,或者使用localdate对象并在每个月将它设置为13之后继续滚动,然后检查它是否为星期五 – Dici