java计算农历日期

java计算农历日期,第1张

import java.util.Scannerpublic class PrintCalendar { /**

* @param args

*/

public static void main(String[] args) {

System.out.println("******************欢 迎 使 用 万 年 历******************")

Scanner input = new Scanner(System.in)

System.out.print("\n请选择年份: ")

int year = input.nextInt()

System.out.print("\n请选择月份: ")

int month = input.nextInt()

System.out.println() int days = 0// 存储当月的天数

boolean isRn

/* 判断是否是闰年 */

if (year % 4 == 0 &&!(year % 100 == 0) || year % 400 == 0) { // 判断是否为闰年

isRn = true// 闰年

} else {

isRn = false// 平年

} /* 计算输入的年份之前的天数 */

int totalDays = 0

for (int i = 1900i <yeari++) {

/* 判断闰年或平年,并进行天数累加 */

if (i % 4 == 0 &&!(i % 100 == 0) || i % 400 == 0) { // 判断是否为闰年

totalDays = totalDays + 366// 闰年366天

} else {

totalDays = totalDays + 365// 平年365天

}

} /* 计算输入月份之前的天数 */

int beforeDays = 0

for (int i = 1i <= monthi++) {

switch (i) {

case 1:

case 3:

case 5:

case 7:

case 8:

case 10:

case 12:

days = 31

break

case 2:

if (isRn) {

days = 29

} else {

days = 28

}

break

default:

days = 30

break

}

if (i <month) {

beforeDays = beforeDays + days

}

}

totalDays = totalDays + beforeDays// 距离1900年1月1日的天数 /* 计算星期几 */

int firstDayOfMonth// 存储当月第一天是星期几:星期日为0,星期一~星期六为1~6

int temp = 1 + totalDays % 7// 从1900年1月1日推算

if (temp == 7) { // 求当月第一天

firstDayOfMonth = 0// 周日

} else {

firstDayOfMonth = temp

} /* 输出日历 */

System.out.println("星期日\t星期一\t星期二\t星期三\t星期四\t星期五\t星期六")

for (int nullNo = 0nullNo <firstDayOfMonthnullNo++) {

System.out.print("\t")// 输出空格

}

for (int i = 1i <= daysi++) {

System.out.print(i + "\t")

if ((totalDays + i - 1) % 7 == 5) { // 如果当天为周六,输出换行

System.out.println()

}

}

}

}

public class TestNongLi {

public static void main(String[] args) {

// 调用农历日期转换阳历日期方法

System.out.println(ChineseCalendar.sCalendarLundarToSolar(2008, 1, 1))

}

}

// 自定义日历类

class ChineseCalendar {

// Array lIntLunarDay is stored in the monthly day information in every year from 1901 to 2100 of the lunar calendar,

// The lunar calendar can only be 29 or 30 days every month, express with 12(or 13) pieces of binary bit in one year,

// it is 30 days for 1 form in the corresponding location , otherwise it is 29 days

private static final int[] iLunarmont


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8010040.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-12
下一篇 2023-04-12

发表评论

登录后才能评论

评论列表(0条)

保存