Java万年历程序

【程序说明】该程序实现了输出任意一年的日历,并输出该年中任意一天是该年的第几周。

【规定】①闰年366天,2月29天;平年365天,2月28天。

             ②周日为某月的第一天,周六为该月的最后一天。

             ③某年的1月1号为该年的第一天,属于该年的第一周。

程序运行结果部分截图如下:

 【注意】2018.01.31和2018.02.01同属于2018年的第5周!

代码如下-Java:

public class WanNianLi {
	//某年是否是润年
	public static boolean isLeapYear(int year){
		boolean isOK;
		isOK = year%4==0 && year%100!=0 || year%400==0 ? true:false;
		return isOK;
	}
	
	//某年有多少天
	public static int yearDays(int year){
		int days;//润年366天二月29天,平年365天二月28天
		return days = isLeapYear(year) ? 366 : 365;
	}
	
	//某年某月有多少天
	public static int yearMonthDays(int year,int month){
		int days = 0;
		switch (month) {
		case 1:
		case 3:
		case 5:
		case 7:
		case 8:
		case 10:
		case 12:
			days=31;
			break;
		case 4:
		case 6:
		case 9:
		case 11:
			days=30;
			break;
		case 2:
			days = isLeapYear(year)?29:28;
			break;
		}
		return days;
	}
	
	//某年某月第一天距离2000.01.01有多少天
	public static int yearMonthDayTo20000101(int year,int month){
		int days = 0;
		if(year>=2000){
			//年
			for (int i = 2000; i < year; i++) {
				days += yearDays(i);
			}
			//月
			for (int j = 1; j < month; j++) {
				days += yearMonthDays(year,j);
			}
		}
		else{
			//eg:1998.06.01
			for (int i = year+1; i<2000; i++) {
				days += yearDays(i);
			}
			for(int j = month ; j<=12; j++){
				days += yearMonthDays(year, j);
			}
		}
		return days;
	}
	
	//某年某月1号是星期几
	public static int weekDay(int year, int month){
		int dayNum = 99;//周日记为0,周六记为6,99代表错误
		int n = yearMonthDayTo20000101(year,month);
		if(year>=2000){
			dayNum = (6+n)%7;
		}
		else{
			dayNum = 6-n%7;
		}
		return dayNum;
	}
	
	//静态变量weekNum表示一天中的某一天属于该年的第几周
	static int weekNum = 0;//周数
	//显示某年某月的日历
	public static void displayYearMonth(int year, int m) {
		System.out.println("\t\t     ————"+year+"———"+m+"————");
		System.out.println("日\t一\t二\t三\t四\t五\t六\t周");
		int count = 0;//定义一个计数器,记录当前将要输出的天在日历表中的位置。例如2018.1.1的count=1
		count = weekDay(year, m);//日历的第一行空多少格,count[0,6]
		for(int j = 0; j < count; j++)//空count-1格,第count的位置打印1号
			System.out.print("\t");
		for(int i = 1; i <= yearMonthDays(year, m); i++){
			if( (count+1)%8 == 0 ){//该输出周数weekNum的时候
				System.out.println(++weekNum);
				count++;
			}
			System.out.print(i+"\t");//输出号数
			count++;//例如2018.01,i=31输出后的count=36,
			if(i==yearMonthDays(year, m)){//输出某月最后一天时
				if( (count+1)%8 != 0){//如果该月的最后一天不是周六
					do {
						System.out.print("\t");
						count++;
					} while ( (count+1)%8 != 0);//当满足条件是继续循环,直到不满足条件时结束循环
				}
				System.out.println(++weekNum);	
				weekNum--;//因为该月的最有一天不是周六,所以下月的第一天与该月的最后一天时同一周
			}
		}
	}
	
	//显示某年的日历
	public static void displayYear(int year){
		for(int m = 1; m <=12; m++){
			displayYearMonth(year,m);
			System.out.println();
		}
	}

	public static void main(String[] args) {
		displayYear(2018);//输出2018年的日历
//		displayYearMonth(2018,1);//输出2018年1月的日历
//		weekDay(2018,6);//输出2018年6月有几天
//		yearMonthDayTo20000101(2018,1);//输出2018年1月1日距离2000.01.01有几天
	}

}

 

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值