java万年历用java语言编写万年历
java万年历  时间:2021-10-20  阅读:(
)
 
 
java万年历
别人写的 借花献佛
万年历的 但是不实现农历
如何计算某一天是星期几?
slowtiger 发表于 2005-10-11 21:43:00 
如何计算某一天是星期几?
—— 蔡勒(Zeller)公式 
历史上的某一天是星期几?未来的某一天是星期几?关于这个问题,有很多计算公式(两个通用计算公式和一些分段计算公式),其中最著名的是蔡勒(Zeller)公式。
即w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1 
公式中的符号含义如下,w:星期;c:世纪-1;y:年(两位数);m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003年1月1日要看作2002年的13月1日来计算);d:日;[ ]代表取整,即只要整数部分。
(C是世纪数减一,y是年份后两位,M是月份,d是日数。
1月和2月要按上一年的13月和 14月来算,这时C和y均按上一年取值。
)
算出来的W除以7,余数是几就是星期几。
如果余数是0,则为星期日。
 
以2049年10月1日(100周年国庆)为例,用蔡勒(Zeller)公式进行计算,过程如下: 
蔡勒(Zeller)公式:w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1 
=49+[49/4]+[20/4]-2×20+[26× (10+1)/10]+1-1 
=49+[12.25]+5-40+[28.6] 
=49+12+5-40+28 
=54 (除以7余5) 
即2049年10月1日(100周年国庆)是星期5。
 
你的生日(出生时、今年、明年)是星期几?不妨试一试。
 
不过,以上公式只适合于1582年10月15日之后的情形(当时的罗马教皇将恺撒大帝制订的儒略历修改成格里历,即今天使用的公历)。
 
过程的推导:(对推理不感兴趣的可略过不看)
星期制度是一种有古老传统的制度。
据说因为《圣经·创世纪》中规定上帝用了六 
天时间创世纪,第七天休息,所以人们也就以七天为一个周期来安排自己的工作和生 
活,而星期日是休息日。
从实际的角度来讲,以七天为一个周期,长短也比较合适。
所 
以尽管中国的传统工作周期是十天(比如王勃《滕王阁序》中说的“十旬休暇”,即是 
指官员的工作每十日为一个周期,第十日休假),但后来也采取了西方的星期制度。
 
 在日常生活中,我们常常遇到要知道某一天是星期几的问题。
有时候,我们还想知 
道历史上某一天是星期几。
通常,解决这个方法的有效办法是看日历,但是我们总不会 
随时随身带着日历,更不可能随时随身带着几千年的万年历。
假如是想在计算机编程中 
计算某一天是星期几,预先把一本万年历存进去就更不现实了。
这时候是不是有办法通 
过什么公式,从年月日推出这一天是星期几呢? 
 答案是肯定的。
其实我们也常常在这样做。
我们先举一个简单的例子。
比如,知道 
了2004年5月1日是星期六,那么2004年5月31日“世界无烟日”是星期几就不难推算出 
来。
我们可以掰着指头从1日数到31日,同时数星期,最后可以数出5月31日是星期一。
 
其实运用数学计算,可以不用掰指头。
我们知道星期是七天一轮回的,所以5月1日是星 
期六,七天之后的5月8日也是星期六。
在日期上,8-1=7,正是7的倍数。
同样,5月15 
日、5月22日和5月29日也是星期六,它们的日期和5月1日的差值分别是14、21和28,也 
都是7的倍数。
那么5月31日呢?31-1=30,虽然不是7的倍数,但是31除以7,余数为2, 
这就是说,5月31日的星期,是在5月1日的星期之后两天。
星期六之后两天正是星期一。
 
 这个简单的计算告诉我们计算星期的一个基本思路:首先,先要知道在想算的日子 
之前的一个确定的日子是星期几,拿这一天做为推算的标准,也就是相当于一个计算的 
“原点”。
其次,知道想算的日子和这个确定的日子之间相差多少天,用7除这个日期 
的差值,余数就表示想算的日子的星期在确定的日子的星期之后多少天。
如果余数是 
0,就表示这两天的星期相同。
显然,如果把这个作为“原点”的日子选为星期日,那 
么余数正好就等于星期几,这样计算就更方便了。
 
 但是直接计算两天之间的天数,还是不免繁琐。
比如1982年7月29日和2004年5月 
1日之间相隔7947天,就不是一下子能算出来的。
它包括三段时间:一,1982年7月29 
日以后这一年的剩余天数;二,1983-2003这二十一个整年的全部天数;三,从2004年 
元旦到5月1日经过的天数。
第二段比较好算,它等于21*365+5=7670天,之所以要加 
5,是因为这段时间内有5个闰年。
第一段和第三段就比较麻烦了,比如第三段,需要把 
5月之前的四个月的天数累加起来,再加上日期值,即31+29+31+30+1=122天。
同理,第 
一段需要把7月之后的五个月的天数累加起来,再加上7月剩下的天数,一共是155天。
 
所以总共的相隔天数是122+7670+155=7947天。
 
 仔细想想,如果把“原点”日子的日期选为12月31日,那么第一段时间也就是一个 
整年,这样一来,第一段时间和第二段时间就可以合并计算,整年的总数正好相当于两 
个日子的年份差值减一。
如果进一步把“原点”日子选为公元前1年12月31日(或者天文 
学家所使用的公元0年12月31日),这个整年的总数就正好是想算的日子的年份减一。
这 
样简化之后,就只须计算两段时间:一,这么多整年的总天数;二,想算的日子是这一 
年的第几天。
巧的是,按照公历的年月设置,这样反推回去,公元前1年12月31日正好是 
星期日,也就是说,这样算出来的总天数除以7的余数正好是星期几。
那么现在的问题就 
只有一个:这么多整年里面有多少闰年。
这就需要了解公历的置闰规则了。
 
 我们知道,公历的平年是365天,闰年是366天。
置闰的方法是能被4整除的年份在 
2月加一天,但能被100整除的不闰,能被400整除的又闰。
因此,像1600、2000、2400 
年都是闰年,而1700、1800、1900、2100年都是平年。
公元前1年,按公历也是闰年。
 
 因此,对于从公元前1年(或公元0年)12月31日到某一日子的年份Y之间的所有整年 
中的闰年数,就等于 
[(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400], 
[...]表示只取整数部分。
第一项表示需要加上被4整除的年份数,第二项表示需要去掉 
被100整除的年份数,第三项表示需要再加上被400整除的年份数。
之所以Y要减一,这 
样,我们就得到了第一个计算某一天是星期几的公式: 
W = (Y-1)*365 + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D. (1) 
其中D是这个日子在这一年中的累积天数。
算出来的W就是公元前1年(或公元0年)12月 
31日到这一天之间的间隔日数。
把W用7除,余数是几,这一天就是星期几。
比如我们来 
算2004年5月1日: 
W = (2004-1)*365 + [(2004-1)/4] - [(2004-1)/100] + [(2004-1)/400] + 
 (31+29+31+30+1) 
 = 731702, 
731702 / 7 = 104528……6,余数为六,说明这一天是星期六。
这和事实是符合的。
 
 上面的公式(1)虽然很准确,但是计算出来的数字太大了,使用起来很不方便。
仔 
细想想,其实这个间隔天数W的用数仅仅是为了得到它除以7之后的余数。
这启发我们是 
不是可以简化这个W值,只要找一个和它余数相同的较小的数来代替,用数论上的术语 
来说,就是找一个和它同余的较小的正整数,照样可以计算出准确的星期数。
 
 显然,W这么大的原因是因为公式中的第一项(Y-1)*365太大了。
其实, 
(Y-1)*365 = (Y-1) * (364+1) 
 = (Y-1) * (7*52+1) 
 = 52 * (Y-1) * 7 + (Y-1), 
这个结果的第一项是一个7的倍数,除以7余数为0,因此(Y-1)*365除以7的余数其实就 
等于Y-1除以7的余数。
这个关系可以表示为: 
(Y-1)*365 ≡ Y-1 (mod 7). 
其中,≡是数论中表示同余的符号,mod 7的意思是指在用7作模数(也就是除数)的情 
况下≡号两边的数是同余的。
因此,完全可以用(Y-1)代替(Y-1)*365,这样我们就得到 
了那个著名的、也是最常见到的计算星期几的公式: 
W = (Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D. (2) 
 这个公式虽然好用多了,但还不是最好用的公式,因为累积天数D的计算也比较麻 
烦。
是不是可以用月份数和日期直接计算呢?答案也是肯定的。
我们不妨来观察一下各 
个月的日数,列表如下: 
月 份:1月 2月 3月 4月 5月 6月 7月 8月 9月 10月 11月 12月 
-------------------------------------------------------------------------- 
天 数: 31 28(29) 31 30 31 30 31 31 30 31 30 31 
如果把这个天数都减去28(=4*7),不影响W除以7的余数值。
这样我们就得到另一张 
表: 
月 份:1月 2月 3月 4月 5月 6月 7月 8月 9月 10月 11月 12月 
------------------------------------------------------------------------ 
剩余天数: 3 0(1) 3 2 3 2 3 3 2 3 2 3 
平年累积: 3 3 6 8 11 13 16 19 21 24 26 29 
闰年累积: 3 4 7 9 12 14 17 20 22 25 27 30 
仔细观察的话,我们会发现除去1月和2月,3月到7月这五个月的剩余天数值是3,2,3,2, 
3;8月到12月这五个月的天数值也是3,2,3,2,3,正好是一个重复。
相应的累积天数中, 
后一月的累积天数和前一月的累积天数之差减去28就是这个重复。
正是因为这种规律的 
存在,平年和闰年的累积天数可以用数学公式很方便地表达: 
 ╭ d; (当M=1) 
D = { 31 + d; (当M=2) (3) 
 ╰ [ 13 * (M+1) / 5 ] - 7 + (M-1) * 28 + d + i. (当M≥3) 
其中[...]仍表示只取整数部分;M和d分别是想算的日子的月份和日数;平年i=0,闰年 
i=1。
对于M≥3的表达式需要说明一下:[13*(M+1)/5]-7算出来的就是上面第二个表中的 
平年累积值,再加上(M-1)*28就是想算的日子的月份之前的所有月份的总天数。
这是一 
个很巧妙的办法,利用取整运算来实现3,2,3,2,3的循环。
比如,对2004年5月1日,有: 
D = [ 13 * (5+1) / 5 ] - 7 + (5-1) * 28 + 1 + 1 
 = 122, 
这正是5月1日在2004年的累积天数。
 
 假如,我们再变通一下,把1月和2月当成是上一年的“13月”和“14月”,不仅仍 
然符合这个公式,而且因为这样一来,闰日成了上一“年”(一共有14个月)的最后一 
天,成了d的一部分,于是平闰年的影响也去掉了,公式就简化成: 
D = [ 13 * (M+1) / 5 ] - 7 + (M-1) * 28 + d. (3≤M≤14) (4) 
上面计算星期几的公式,也就可以进一步简化成: 
W = (Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + [ 13 * (M+1) / 5 ] - 7 
 + (M-1) * 28 + d. 
因为其中的-7和(M-1)*28两项都可以被7整除,所以去掉这两项,W除以7的余数不变, 
公式变成: 
W = (Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + [ 13 * (M+1) / 5 ] + d. 
 (5) 
当然,要注意1月和2月已经被当成了上一年的13月和14月,因此在计算1月和2月的日子 
的星期时,除了M要按13或14算,年份Y也要减一。
比如,2004年1月1日是星期四,用这 
个公式来算,有: 
W = (2003-1) + [(2003-1)/4] - [(2003-1)/100] + [(2003-1)/400] + [13*(13+1)/5] 
 + 1 
 = 2002 + 500 - 20 + 5 + 36 + 1 
 = 2524; 
2524 / 7 = 360……4.这和实际是一致的。
 
 公式(5)已经是从年、月、日来算星期几的公式了,但它还不是最简练的,对于年 
份的处理还有改进的方法。
我们先来用这个公式算出每个世纪第一年3月1日的星期,列 
表如下: 
年份: 1(401,801,…,2001) 101(501,901,…,2101) 
-------------------------------------------------------------------- 
星期: 4 2 
==================================================================== 
年份:201(601,1001,…,2201) 301(701,1101,…,2301) 
-------------------------------------------------------------------- 
星期: 0 5 
可以看出,每隔四个世纪,这个星期就重复一次。
假如我们把301(701,1101,…,2301) 
年3月1日的星期数看成是-2(按数论中对余数的定义,-2和5除以7的余数相同,所以可 
以做这样的变换),那么这个重复序列正好就是一个4,2,0,-2的等差数列。
据此,我们 
可以得到下面的计算每个世纪第一年3月1日的星期的公式: 
W = (4 - C mod 4) * 2 - 4. (6) 
式中,C是该世纪的世纪数减一,mod表示取模运算,即求余数。
比如,对于2001年3月 
1日,C=20,则: 
W = (4 - 20 mod 4) * 2 - 4 
 = 8 - 4 
 = 4. 
 把公式(6)代入公式(5),经过变换,可得: 
(Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] ≡ (4 - C mod 4) * 2 - 1 
(mod 7). (7) 
因此,公式(5)中的(Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400]这四项,在计算 
每个世纪第一年的日期的星期时,可以用(4 - C mod 4) * 2 - 1来代替。
这个公式写 
出来就是: 
W = (4 - C mod 4) * 2 - 1 + [13 * (M+1) / 5] + d. (8) 
有了计算每个世纪第一年的日期星期的公式,计算这个世纪其他各年的日期星期的公式 
就很容易得到了。
因为在一个世纪里,末尾为00的年份是最后一年,因此就用不着再考 
虑“一百年不闰,四百年又闰”的规则,只须考虑“四年一闰”的规则。
仿照由公式(1) 
简化为公式(2)的方法,我们很容易就可以从式(8)得到一个比公式(5)更简单的计算任意 
一天是星期几的公式: 
W = (4 - C mod 4) * 2 - 1 + (y-1) + [y/4] + [13 * (M+1) / 5] + d. (9) 
式中,y是年份的后两位数字。
 
 如果再考虑到取模运算不是四则运算,我们还可以把(4 - C mod 4) * 2进一步改写 
成只含四则运算的表达式。
因为世纪数减一C除以4的商数q和余数r之间有如下关系: 
4q + r = C, 
其中r即是 C mod 4,因此,有: 
r = C - 4q 
 = C - 4 * [C/4]. (10) 
则 
(4 - C mod 4) * 2 = (4 - C + 4 * [C/4]) * 2 
 = 8 - 2C + 8 * [C/4] 
 ≡ [C/4] - 2C + 1 (mod 7). (11) 
把式(11)代入(9),得到: 
W = [C/4] - 2C + y + [y/4] + [13 * (M+1) / 5] + d - 1. (12) 
这个公式由世纪数减一、年份末两位、月份和日数即可算出W,再除以7,得到的余数是 
几就表示这一天是星期几,唯一需要变通的是要把1月和2月当成上一年的13月和14月, 
C和y都按上一年的年份取值。
因此,人们普遍认为这是计算任意一天是星期几的最好的 
公式。
这个公式最早是由德国数学家克里斯蒂安·蔡勒(Christian Zeller, 1822- 
1899)在1886年推导出的,因此通称为蔡勒公式(Zeller’s Formula)。
为方便口算, 
式中的[13 * (M+1) / 5]也往往写成[26 * (M+1) / 10]。
 
 现在仍然让我们来算2004年5月1日的星期,显然C=20,y=4,M=5,d=1,代入蔡勒 
公式,有: 
W = [20/4] - 40 + 4 + 1 + [13 * (5+1) / 5] + 1 - 1 
 = -15. 
注意负数不能按习惯的余数的概念求余数,只能按数论中的余数的定义求余。
为了方便 
计算,我们可以给它加上一个7的整数倍,使它变为一个正数,比如加上70,得到55。
 
再除以7,余6,说明这一天是星期六。
这和实际是一致的,也和公式(2)计算所得的结 
果一致。
 
 最后需要说明的是,上面的公式都是基于公历(格里高利历)的置闰规则来考虑 
的。
对于儒略历,蔡勒也推出了相应的公式是: 
W = 5 - C + y + [y/4] + [13 * (M+1) / 5] + d - 1. (13) 
 ========================================
(2005-10-20 22:25:00) --------(4575252)
计算任何一天是星期几的几种算法 
近日在论坛上看到有人在问星期算法,特别整理了一下,这些算法都是从网上搜索而来,算法的实现是我在项目中写的。
希望对大家有所帮助。
 
一:常用公式
 W = [Y-1] + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D
 Y是年份数,D是这一天在这一年中的累积天数,也就是这一天在这一年中是第几天。
二:蔡勒(Zeller)公式
 w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
 公式中的符号含义如下,w:星期;c:世纪;y:年(两位数); m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003年1月1日要看作2002年的13月1日来计算);d:日;[ ]代表取整,即只要整数部分。
 相比于通用通用计算公式而言,蔡勒(Zeller)公式大大降低了计算的复杂度。
 三:对蔡勒(Zeller)公式的改进
作者:冯思琮
 相比于另外一个通用通用计算公式而言,蔡勒(Zeller)公式大大降低了计算的复杂度。
不过,笔者给出的通用计算公式似乎更加简洁(包括运算过程)。
现将公式列于其下:
W=[y/4]+r (y/7)-2r(c/4)+m’+d
公式中的符号含义如下,r ( )代表取余,即只要余数部分;m’是m的修正数,现给出1至12月的修正数1’至12’如下:(1’,10’)=6;(2’,3’,11’)=2;(4’,7’)=5;5’=0;6’=3;8’=1;(9’,12’)=4(注意:在笔者给出的公式中,y为润年时1’=5;2’=1)。
其他符号与蔡勒(Zeller)公式中的含义相同。
四:基姆拉尔森计算公式
 这个公式名称是我给命名的,哈哈希望大家不要见怪。
W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7
 在公式中d表示日期中的日数,m表示月份数,y表示年数。
注意:在公式中有个与其他公式不同的地方:
 把一月和二月看成是上一年的十三月和十四月,例:如果是2004-1-10则换算成:2003-13-10来代入公式计算。
如何用Java编写一个万年历
/*
题目:输出任意年份e799bee5baa6e79fa5e9819331333361326239任意月份的日历表(公元后)
思路:
????1.已知1年1月1日是星期日,1?%?7?=?1?对应的是星期日,2?%?7?=?2?对应的是星期一,以此类推;
????2.计算当年以前所有天数+当年当月1号之前所有天数;
??????a.年份分平年闰年,平年365天,闰年366天;
??????b.闰年的判断方法year?%?400?==?0?||?(year?%?100?!=?0?&&?year?%?4?==?0)若为真,则为闰年否则为平年;
??????c.定义平年/闰年数组,包含各月天数;
??????d.遍历数组求和,计算当年当月前总天数;
??????e.当年以前所有天数+当年当月前总天数+1即为1年1月1日到当年当月1日的总天数;
????3.总天数对7取模,根据结果判断当月1号是星期几,输出空白区域;
????4.输出当月日历表,逢星期六换行
*/
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();
????????????????}
????????????}
????????}
????}
}如何用java语言 写出一个万年历呢? 要求自己输入年份 自动出现月 日 以及对应的星期
import java.util.*;
public class B{
 public static void main(String []args){
  System.out.println("Please input the year");
  Scanner scanner =new Scanner(System.in);
  int year=0;
  int day=0;
  int week=0;   
  try{
   year=scanner.nextInt();
   System.out.println("the  calendar by"+year+"year");
  }
   catch(Exception ex){
  System.out.println("Please enter an integer");
  }
  Calendar   now   =   Calendar.getInstance(); 
  for(int i=1;i<=12;i++){
   switch(i){
            case 1:
            case 3:
            case 5:
            case 7:
            case 8:
            case 10:
            case 12:
      day= 31;
                break;
            case 4:
            case 6:
            case 9:
            case 11:
                day = 30;
                break;
            case 2:
                if ((year % 4 == 0 && year% 100 != 0) || year % 400 == 0) {
                   day = 29;
                } else {
                   day = 28;
                }
    }
                 now.set(year,i-1,1); 
                 week   =   now.get(Calendar.DAY_OF_WEEK); 
   boolean toweek=false;
   System.out.println(year+"年"+i+"月");
   System.out.println("  日  "+"  一  "+"  二  "+"  三  "+"  四  "+"  五  "+"  六  ");
  for(int num=1;num<=day;){
   for(int j=1;j<=7;){
    if(!toweek){
     if(j!=week){
      System.out.print("      ");
      j++;
     }else{
      toweek=true;
     }
    }
    if(toweek){
     if(num<10){
      System.out.print("   "+num+"  ");
     }
     else{System.out.print("  "+num+"  ");}
     j++;
     num++;
     if(num>day){
     break;
    }
    }
   } 
   System.out.println();
   }
   System.out.println();
   System.out.println();
  }
 }
}
类名B用java语言编写万年历
给你一个现成的,我自己写的。
import java.awt.*;
import java.util.*;
import javax.swing.*;
import java.awt.event.*;
public class WanNianLi extends JFrame implements ActionListener {
 private static int year,month,days;
 private JButton[] btn=new JButton[days];
 WanNianLi() {
 super("万年历");
 setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
 GridLayout bl=new GridLayout(5,7);
 JPanel pane=new JPanel();
 pane.setLayout(bl);
 for (int i=0;i<days;i++) {
 int temp=i+1;
 btn[i]=new JButton(""+temp);
 btn[i].addActionListener(this);
 pane.add(btn[i]);
 }
 setContentPane(pane);
 pack();
 setLookAndFeel();
 setVisible(true);
 }
 public static void main(String[] args) {
 if (args.length>0)
 year=Integer.parseInt(args[0]);
 else
 year=1982;
 if (args.length>1)
 month=Integer.parseInt(args[1]);
 else
 month=1;
 GetDays gd=new GetDays(year,month);
 days=gd.getDays();
 new WanNianLi();
 }
 public void actionPerformed(ActionEvent evt) {
 Object src=evt.getSource();
 for (int i=0;i<days;i++)
 if (src==btn[i]) { 
 int day=i+1;
 GetWeekday gw=new GetWeekday(year,month,day);
 String str="";
 switch (gw.getWeekday()) {
 case 1:
 str="天";
 break;
 case 2:
 str="一";
 break;
 case 3:
 str="二";
 break;
 case 4:
 str="三";
 break;
 case 5:
 str="四";
 break;
 case 6:
 str="五";
 break;
 case 7:
 str="六";
 break;
 }
 setTitle(year+"年"+month+"月"+day+"日"+"星期"+str);
 repaint();
 }
 }
 private void setLookAndFeel() {
 try {
 UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
 SwingUtilities.updateComponentTreeUI(this);
 }catch(Exception e){
 System.out.print(e.toString());
 }
 }
}
//////////////
//获取星期几//
//////////////
class GetWeekday {
 private Calendar cal=Calendar.getInstance();
 private static int weekday;
 public int getWeekday() {
 return weekday;
 }
 GetWeekday(int y,int m,int d) {
 cal.clear();
 cal.set(Calendar.YEAR,y);
 cal.set(Calendar.MONTH,m-1);
 cal.set(Calendar.DAY_OF_MONTH,d);
 weekday=cal.get(Calendar.DAY_OF_WEEK);
 }
}
////////////////////
//获取当前月的天数//
//////////////////// 
class GetDays {
 private static int days;
 public int getDays() {
 return days;
 }
 GetDays(int y,int m) {
 GregorianCalendar gc=new GregorianCalendar();
 switch (m) {
 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:
 if (gc.isLeapYear(y))
 days=29;
 else
 days=28;
 break;
 }
 }
} 
		  
		  
		      
			  
		  
			  			   
			      
			        
			          
			          vollcloud LLC创立于2020年,是一家以互联网基础业务服务为主的 技术型企业,运营全球数据中心业务。致力于全球服务器租用、托管及云计算、DDOS安 全防护、数据实时存储、 高防服务器加速、域名、智能高防服务器、网络安全服务解决方案等领域的智 能化、规范化的体验服务。所有购买年付产品免费更换香港原生IP(支持解锁奈飞),商家承诺,支持3天内无条件退款(原路退回)!点击进入:vollclo...
			         
			       
				  
			     
							   
			      
			        
			          
			          CloudServer是一家新的VPS主机商,成立了差不多9个月吧,提供基于KVM架构的VPS主机,支持Linux或者Windows操作系统,数据中心在美国纽约、洛杉矶和芝加哥机房,都是ColoCrossing的机器。目前商家在LEB提供了几款特价套餐,最低月付4美元(或者$23.88/年),购买更高级别套餐还能三个月费用使用6个月,等于前半年五折了。下面列出几款特别套餐配置信息。CPU:1cor...
			         
			       
				  
			     
							   
			      
			        
			          
			          Mineserver(ASN142586|UK CompanyNumber 1351696),已经成立一年半。主营香港日本机房的VPS、物理服务器业务。Telegram群组: @mineserver1 | Discord群组: https://discord.gg/MTB8ww9GEA7折循环优惠:JP30(JPCN2宣布产品可以使用)8折循环优惠:CMI20(仅1024M以上套餐可以使用)9折循...
			         
			       
				  
			     
							
			   
			   
java万年历为你推荐
	唐宛如扮演者小时代3女主角名字叫什么四人?八度空间网上论坛八度空间的涵义????贪婪之刃我真是不理解贪婪之刃这个装备,到底有什么叼用罗斯柴尔德家族现状罗斯切尔德家族的现状网上秘书做秘书要学习什么办公软件破泞之战第二幕怎样完成暗黑破坏神2第二幕的最后一个任务f4nn难道f4nn被丰了cOM怎么空白了芈怎么读(芈)和(蚩)怎么读?拼音是什么?拥趸者范思哲服饰简介2012韦博英语价格表韦伯英语价格贵吗?
猫咪av永久最新域名 代理域名备案 域名备案中心 动态域名解析软件 edgecast 美国主机论坛 rak机房 缓存服务器 一元域名 网站挂马检测工具 合肥鹏博士 免费个人空间 新家坡 静态空间 东莞数据中心 七夕快乐英语 下载速度测试 秒杀品 阿里云手机官网 万网注册 更多