java循环小游戏(任意月份日历表)

718 阅读4分钟

题目: 输出任意年份任意月份的日历表(公元后)

显示效果:

12267107.png

  1. 思路:
    1. 判断1年1月1日是星期几,1 % 7 = 1 对应的是1年1月1日的星期数,2 % 7 = 2对应的是1年1月2日的星期数,以此类推;
    2. 计算(当年以前所有天数+当年当月1号之前所有天数);
    3. 年份分平年闰年,平年365天,闰年366天;
    4. 闰年的判断方法year % 400 == 0 || (year % 100 != 0 && year % 4 == 0)若为真,则为闰年否则为平年;
    5. 定义平年/闰年数组,包含各月天数;
    6. 遍历数组求和,计算当年当月前总天数;
    7. (当年以前所有天数+当年当月前总天数+1)即为1年1月1日到当年当月1日的总天数;
    8. 总天数对7取模,根据结果判断当月1号是星期几,输出空白区域;
    9. 输出当月日历表,逢星期六换行
  2. 代码1:判断1年1月1日是星期几
/*
题目:已知2016年1月1日是星期五,判断0001年1月1日是星期几
思路:
	1.算出0001年1月1日到2016年1月1日共几天
	2.然后用天数对7取模,判断星期几
*/
class JudgeZero {
	public static void main(String[] args) {
		int totalDay = (((2016 - 1) / 4 * 366) + (2016 - 1 - ((2016-1) / 4)) * 365) + 1;
		int zeroWeek = 1 % 7 - (totalDay % 7 - 5);
		switch (zeroWeek) {
		case 1 :
			System.out.println("0001年1月1日是星期一");
			break;
		case 2 :
			System.out.println("0001年1月1日是星期二");
			break;
		case 3 :
			System.out.println("0001年1月1日是星期三");
			break;
		case 4 :
			System.out.println("0001年1月1日是星期四");
			break;
		case 5 :
			System.out.println("0001年1月1日是星期五");
			break;
		case 6 :
			System.out.println("0001年1月1日是星期六");
			break;
		case 0 :
			System.out.println("0001年1月1日是星期日");
			break;
		default :
			System.out.println("输入错误!");
		}					
	}
}
  1. 输出结果:

    11480987.png

  2. 代码2:输出日历表

import java.util.Scanner;
class FindMonthList {
	public static void main(String[] args){
		Scanner sc = new Scanner(System.in);
		System.out.println("请输入年份:");
		int year = sc.nextInt();			//年份
		if (year < 1) {						//判断非法输入年份
			System.out.println("输入错误!");
			return;
		}
		System.out.println("请输入月份:");
		int month = sc.nextInt();			//月份
		if (month < 1 || month > 12) {		//判断非法输入月份
			System.out.println("输入错误!");
			return;
		}
		//输出表头
		System.out.println("-------" + year + " 年 " + month + " 月 " + "-------");
		System.out.println();
		System.out.println("日  一  二  三  四  五  六");

		//计算当前年份以前所有天数beforeYearTotalDay;每4年一个闰年,闰年366天,平年365天
		int beforeYearTotalDay = ((year - 1) / 4 * 366) + (year-1 - ((year - 1) / 4)) * 365;
		int[] arrLeapYear = {0,31,29,31,30,31,30,31,31,30,31,30,31};	//闰年各月天数	int数组
		int[] arrNormalYear = {0,31,28,31,30,31,30,31,31,30,31,30,31};	//平年各月天数	int数组
		int beforeMonthTotalDay = 0;									//定义本年当月之前月份的总天数
		if (year % 400 == 0 || (year % 100 != 0 && year % 4 == 0)) {		//判断当前年份是否是闰年
			for (int i = 0 ; i < month ; i ++ ) {	//for循环计算当月之前总天数
				//计算当前月份之前的所有天数
				beforeMonthTotalDay = beforeMonthTotalDay + arrLeapYear[i];
			}
			//判断当月1日是星期几
			int totalDay = beforeYearTotalDay + beforeMonthTotalDay + 1;
			int week = totalDay % 7;//已知1年1月1日是星期日,即模7得1对应的是星期日
			for (int i = 0 ; i < (week - 1 + 7) % 7 ; i ++) {	//如果写成i < (week-1)会出现i<-1的情况
				System.out.print("    ");//输出开头空白
			}
			for (int i = 1 ;i <= arrLeapYear[month] ;i ++ ) {	//for循环输出各月天数
				System.out.print(i + "  ");
				if (i < 10 ) {		//小于10的数补一个空格,以便打印整齐
					System.out.print(" ");
				}
				if (i % 7 == ((7-(week - 1)) % 7 ) || i == arrLeapYear[month]) {//每逢星期六/尾数换行
					System.out.println();
				}
			}

		} else {		//不是闰年就是平年
			for (int i = 0 ; i < month ; i ++ ) {	//for循环计算出当月之前月份总天数
				beforeMonthTotalDay = beforeMonthTotalDay + arrNormalYear[i];
			}
			//判断当月1日是星期几
			int totalDay = beforeYearTotalDay + beforeMonthTotalDay + 1;
			int week = totalDay % 7;//已知1年1月1日是星期日,即模7得1对应的是星期日
			for (int i = 0 ; i < (week - 1 + 7) % 7 ; i ++) {	//如果写成i < (week-1)会出现i<-1的情况
				System.out.print("    ");//输出开头空白
			}
			for (int i = 1 ;i <= arrNormalYear[month] ;i ++ ) {//for循环输出各月天数
				System.out.print(i + "  ");
				if (i < 10 ) {			//小于10的数补一个空格,以便打印整齐
					System.out.print(" ");
				}
				if (i % 7 == ((7-(week - 1)) % 7 ) || i == arrNormalYear[month]) {//每逢星期六/尾数换行
					System.out.println();
				}
			}
		}
	}
}
  1. 输出结果:
    8703014.png
  2. 总结:
  • 代码还很臃肿,需要继续优化;
  • 对于数组的理解还很浅显,下一步学习数组定义,用一个数组解决平闰年的问题;
  • 类名、变量名命名不规范,意思不易理解。