• 博客分类:
  • java
java二十四节气二十四节气公式C值 
import java.util.HashMap; 
import java.util.Map;

/** 
*@author:518ad-ccn 
*date:Dec 13, 2011 
*describe:24节气 
*注:程序中使用到的计算节气公式、节气世纪常量等相关信息参照http://www.360doc.com/content/11/0106/22/5281066_84591519.shtml, 
*程序的运行得出的节气结果绝大多数是正确的,有少数部份是有误差的 
*/ 
public class _24SolarTerms { 
private static final  double D = 0.2422; 
private final static Map<String,Integer[]> INCREASE_OFFSETMAP = new HashMap<String, Integer[]>();//+1偏移
private final static Map<String,Integer[]> DECREASE_OFFSETMAP = new HashMap<String, Integer[]>();//-1偏移

/**24节气**/ 
private static enum SolarTermsEnum { 
LICHUN,//--立春 
YUSHUI,//--雨水 
JINGZHE,//--惊蛰 
CHUNFEN,//春分 
QINGMING,//清明 
GUYU,//谷雨 
LIXIA,//立夏 
XIAOMAN,//小满 
MANGZHONG,//芒种 
XIAZHI,//夏至 
XIAOSHU,//小暑 
DASHU,//大暑 
LIQIU,//立秋 
CHUSHU,//处暑 
BAILU,//白露 
QIUFEN,//秋分 
HANLU,//寒露 
SHUANGJIANG,//霜降 
LIDONG,//立冬 
XIAOXUE,//小雪 
DAXUE,//大雪 
DONGZHI,//冬至 
XIAOHAN,//小寒 
DAHAN;//大寒 
}

static { 
DECREASE_OFFSETMAP.put(SolarTermsEnum.YUSHUI.name(), new Integer[]{2026});//雨水 
INCREASE_OFFSETMAP.put(SolarTermsEnum.CHUNFEN.name(), new Integer[]{2084});//春分 
INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAOMAN.name(), new Integer[]{2008});//小满 
INCREASE_OFFSETMAP.put(SolarTermsEnum.MANGZHONG.name(), new Integer[]{1902});//芒种 
INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAZHI.name(), new Integer[]{1928});//夏至 
INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAOSHU.name(), new Integer[]{1925,2016});//小暑 
INCREASE_OFFSETMAP.put(SolarTermsEnum.DASHU.name(), new Integer[]{1922});//大暑 
INCREASE_OFFSETMAP.put(SolarTermsEnum.LIQIU.name(), new Integer[]{2002});//立秋 
INCREASE_OFFSETMAP.put(SolarTermsEnum.BAILU.name(), new Integer[]{1927});//白露 
INCREASE_OFFSETMAP.put(SolarTermsEnum.QIUFEN.name(), new Integer[]{1942});//秋分 
INCREASE_OFFSETMAP.put(SolarTermsEnum.SHUANGJIANG.name(), new Integer[]{2089});//霜降 
INCREASE_OFFSETMAP.put(SolarTermsEnum.LIDONG.name(), new Integer[]{2089});//立冬 
INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAOXUE.name(), new Integer[]{1978});//小雪 
INCREASE_OFFSETMAP.put(SolarTermsEnum.DAXUE.name(), new Integer[]{1954});//大雪 
DECREASE_OFFSETMAP.put(SolarTermsEnum.DONGZHI.name(), new Integer[]{1918,2021});//冬至

INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAOHAN.name(), new Integer[]{1982});//小寒 
DECREASE_OFFSETMAP.put(SolarTermsEnum.XIAOHAN.name(), new Integer[]{2019});//小寒

INCREASE_OFFSETMAP.put(SolarTermsEnum.DAHAN.name(), new Integer[]{2082});//大寒 
}

//定义一个二维数组,第一维数组存储的是20世纪的节气C值,第二维数组存储的是21世纪的节气C值,0到23个,依次代表立春、雨水...大寒节气的C值 
private static final double[][] CENTURY_ARRAY = 
{{4.6295,19.4599,6.3826,21.4155,5.59,20.888,6.318,21.86,6.5,22.2,7.928,23.65,8.35, 
23.95,8.44,23.822,9.098,24.218,8.218,23.08,7.9,22.6,6.11,20.84} 
,{3.87,18.73,5.63,20.646,4.81,20.1,5.52,21.04,5.678,21.37,7.108,22.83, 
7.5,23.13,7.646,23.042,8.318,23.438,7.438,22.36,7.18,21.94,5.4055,20.12}};

/** 

* @param year 年份 
* @param name 节气的名称 
* @return 返回节气是相应月份的第几天 
*/ 
public static int getSolarTermNum(int year,String name){

double centuryValue = 0;//节气的世纪值,每个节气的每个世纪值都不同 
name = name.trim().toUpperCase(); 
int ordinal = SolarTermsEnum.valueOf(name).ordinal();

int centuryIndex = -1; 
if(year>=1901 && year<=2000){//20世纪 
centuryIndex = 0; 
} else if(year>=2001 && year <= 2100){//21世纪 
centuryIndex = 1; 
} else { 
throw new RuntimeException("不支持此年份:"+year+",目前只支持1901年到2100年的时间范围"); 

centuryValue = CENTURY_ARRAY[centuryIndex][ordinal]; 
int dateNum = 0; 
/** 
* 计算 num =[Y*D+C]-L这是传说中的寿星通用公式 
* 公式解读:年数的后2位乘0.2422加C(即:centuryValue)取整数后,减闰年数 
*/ 
int y = year%100;//步骤1:取年分的后两位数 
if(year%4 == 0 && year%100 !=0 || year%400 ==0){//闰年 
if(ordinal == SolarTermsEnum.XIAOHAN.ordinal() || ordinal == SolarTermsEnum.DAHAN.ordinal() 
|| ordinal == SolarTermsEnum.LICHUN.ordinal() || ordinal == SolarTermsEnum.YUSHUI.ordinal()){ 
//注意:凡闰年3月1日前闰年数要减一,即:L=[(Y-1)/4],因为小寒、大寒、立春、雨水这两个节气都小于3月1日,所以 y = y-1 
y = y-1;//步骤2 


dateNum = (int)(y*D+centuryValue)-(int)(y/4);//步骤3,使用公式[Y*D+C]-L计算 
dateNum += specialYearOffset(year,name);//步骤4,加上特殊的年分的节气偏移量 
return dateNum; 
}

/** 
* 特例,特殊的年分的节气偏移量,由于公式并不完善,所以算出的个别节气的第几天数并不准确,在此返回其偏移量 
* @param year 年份 
* @param name 节气名称 
* @return 返回其偏移量 
*/ 
public static int specialYearOffset(int year,String name) { 
int offset = 0; 
offset += getOffset(DECREASE_OFFSETMAP,year,name,-1); 
offset += getOffset(INCREASE_OFFSETMAP,year,name,1);

return offset; 
}

public static int getOffset(Map<String,Integer[]> map,int year,String name,int offset){ 
int off = 0; 
Integer[] years = map.get(name); 
if(null != years){ 
for(int i:years){ 
if(i == year){ 
off = offset; 
break; 



return off; 
}

public static String solarTermToString(int year) { 
StringBuffer sb = new StringBuffer(); 
sb.append("---").append(year); 
if(year%4 == 0 && year%100 !=0 || year%400 ==0){//闰年 
sb.append(" 闰年"); 
} else { 
sb.append(" 平年"); 
}

sb.append("\n") 
.append("立春:2月").append(getSolarTermNum(year,SolarTermsEnum.LICHUN.name())) 
.append("日,雨水:2月").append(getSolarTermNum(year,SolarTermsEnum.YUSHUI.name())) 
.append("日,惊蛰:3月").append(getSolarTermNum(year,SolarTermsEnum.JINGZHE.name())) 
.append("日,春分:3月").append(getSolarTermNum(year,SolarTermsEnum.CHUNFEN.name())) 
.append("日,清明:4月").append(getSolarTermNum(year,SolarTermsEnum.QINGMING.name())) 
.append("日,谷雨:4月").append(getSolarTermNum(year,SolarTermsEnum.GUYU.name())) 
.append("日,立夏:5月").append(getSolarTermNum(year,SolarTermsEnum.LIXIA.name())) 
.append("日,小满:5月").append(getSolarTermNum(year,SolarTermsEnum.XIAOMAN.name())) 
.append("日,芒种:6月").append(getSolarTermNum(year,SolarTermsEnum.MANGZHONG.name())) 
.append("日,夏至:6月").append(getSolarTermNum(year,SolarTermsEnum.XIAZHI.name())) 
.append("日,小暑:7月").append(getSolarTermNum(year,SolarTermsEnum.XIAOSHU.name())) 
.append("日,大暑:7月").append(getSolarTermNum(year,SolarTermsEnum.DASHU.name())) 
.append("日,\n立秋:8月").append(getSolarTermNum(year,SolarTermsEnum.LIQIU.name())) 
.append("日,处暑:8月").append(getSolarTermNum(year,SolarTermsEnum.CHUSHU.name())) 
.append("日,白露:9月").append(getSolarTermNum(year,SolarTermsEnum.BAILU.name())) 
.append("日,秋分:9月").append(getSolarTermNum(year,SolarTermsEnum.QIUFEN.name())) 
.append("日,寒露:10月").append(getSolarTermNum(year,SolarTermsEnum.HANLU.name())) 
.append("日,霜降:10月").append(getSolarTermNum(year,SolarTermsEnum.SHUANGJIANG.name())) 
.append("日,立冬:11月").append(getSolarTermNum(year,SolarTermsEnum.LIDONG.name())) 
.append("日,小雪:11月").append(getSolarTermNum(year,SolarTermsEnum.XIAOXUE.name())) 
.append("日,大雪:12月").append(getSolarTermNum(year,SolarTermsEnum.DAXUE.name())) 
.append("日,冬至:12月").append(getSolarTermNum(year,SolarTermsEnum.DONGZHI.name())) 
.append("日,小寒:1月").append(getSolarTermNum(year,SolarTermsEnum.XIAOHAN.name())) 
.append("日,大寒:1月").append(getSolarTermNum(year,SolarTermsEnum.DAHAN.name()));

return sb.toString(); 
}

public static void main(String[] args) { 
for(int year=1901;year<2050;year++){ 
System.out.println(solarTermToString(year)); 


}

//##########输出########### 
---2009 平年 
立春:2月4日,雨水:2月18日,惊蛰:3月5日,春分:3月20日,清明:4月4日,谷雨:4月20日,立夏:5月5日,小满:5月21日,芒种:6月5日,夏至:6月21日,小暑:7月7日,大暑:7月23日, 
立秋:8月7日,处暑:8月23日,白露:9月7日,秋分:9月23日,寒露:10月8日,霜降:10月23日,立冬:11月7日,小雪:11月22日,大雪:12月7日,冬至:12月22日,小寒:1月5日,大寒:1月20 
---2010 平年 
立春:2月4日,雨水:2月19日,惊蛰:3月6日,春分:3月21日,清明:4月5日,谷雨:4月20日,立夏:5月5日,小满:5月21日,芒种:6月6日,夏至:6月21日,小暑:7月7日,大暑:7月23日, 
立秋:8月7日,处暑:8月23日,白露:9月8日,秋分:9月23日,寒露:10月8日,霜降:10月23日,立冬:11月7日,小雪:11月22日,大雪:12月7日,冬至:12月22日,小寒:1月5日,大寒:1月20 
---2011 平年 
立春:2月4日,雨水:2月19日,惊蛰:3月6日,春分:3月21日,清明:4月5日,谷雨:4月20日,立夏:5月6日,小满:5月21日,芒种:6月6日,夏至:6月22日,小暑:7月7日,大暑:7月23日, 
立秋:8月8日,处暑:8月23日,白露:9月8日,秋分:9月23日,寒露:10月8日,霜降:10月24日,立冬:11月8日,小雪:11月23日,大雪:12月7日,冬至:12月22日,小寒:1月6日,大寒:1月20 
---2012 闰年 
立春:2月4日,雨水:2月19日,惊蛰:3月5日,春分:3月20日,清明:4月4日,谷雨:4月20日,立夏:5月5日,小满:5月20日,芒种:6月5日,夏至:6月21日,小暑:7月7日,大暑:7月22日, 
立秋:8月7日,处暑:8月23日,白露:9月7日,秋分:9月22日,寒露:10月8日,霜降:10月23日,立冬:11月7日,小雪:11月22日,大雪:12月7日,冬至:12月21日,小寒:1月6日,大寒:1月20

java实现二十四节气计算相关推荐

  1. Java基础-时间复杂度计算方式

    Java基础-时间复杂度计算方式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.   时间复杂度通常是衡量算法的优劣的,衡量算法的时间严格来讲是很难衡量的,由于不同的机器性能不用环境 ...

  2. java精确除法计算,四舍五入 Java问题通用解决代码

    java精确除法计算,四舍五入 Java问题通用解决代码 参考文章: (1)java精确除法计算,四舍五入 Java问题通用解决代码 (2)https://www.cnblogs.com/svenne ...

  3. Java判断工作日计算,计算随意2个日期内的工作日

    当前位置:我的异常网» Java Web开发 » 计算随意2个日期内的工作日 计算随意2个日期内的工作日 www.myexceptions.net  网友分享于:2013-08-17  浏览:51次 ...

  4. 【Java】Float计算不准确

    大家可能都遇到过,float在计算某些值时,会有不准确的情况. 比如如下情况: > 计算不准确 package com.nicchagil.study.java.demo.No10float计算 ...

  5. Java练习 SDUT-1586_计算组合数

    计算组合数 Time Limit: 1000 ms Memory Limit: 32768 KiB Problem Description 计算组合数.C(n,m),表示从n个数中选择m个的组合数. ...

  6. java 多线程统计质数,Java 七 多线程计算某个范围内的质数

    Java 7 多线程计算某个范围内的质数 不多说了,看代码 通用类 package java7.concurrency.math; /** * This class generates prime n ...

  7. java指定日期计算一年内第几天和给出一年内第几天算出指定日期

    java指定日期计算一年内第几天和给出一年内第几天算出指定日期 1.计算一年内第几天,部分参考的是https://blog.csdn.net/xinpengfei521/article/details ...

  8. Java实现标题相似度计算,文本内容相似度匹配,Java通过SimHash计算标题文本内容相似度

     目录 一.前言 二.关于SimHash 补充知识 一).什么是海明距离 二).海明距离的应用 三).什么是编辑距离 三.SimHash算法的几何意义和原理 一).SimHash算法的几何意义 二). ...

  9. java 计算星座算法,java 依据生日计算星座

    当前位置:我的异常网» 编程 » java 依据生日计算星座 java 依据生日计算星座 www.myexceptions.net  网友分享于:2013-09-06  浏览:344次 java 根据 ...

最新文章

  1. 异步通知是什么意思_一次相亲经历,我彻底搞懂了阻塞非阻塞、同步异步
  2. JQuery绑定事件 时如何传递参数
  3. openshift用户管理_OpenShift Express Web管理控制台:入门
  4. VMware下Centos7快速搭建vsftpd
  5. 字节跳动推“头条搜索”独立APP 安卓端已上线
  6. python invalid syntax string_Python报错,“SyntaxError: invalid syntax”
  7. Java开发遇到的问题及解决方案
  8. electron 读取文件夹内容_electron + jQuery +node.js 快速上手之实现写入文件、拖拽打开文件并读取内容的功能...
  9. amd显卡测试帧数显示软件,NVIDIA发布帧数显示及显卡基准测试应用FrameView
  10. 什么地图可以室内导航?室内导航技术发展趋势
  11. 关于 Win10 下使用 IETester 的问题
  12. php下一页的代码,php 下一页的代码
  13. html母亲节主题网页源码jd
  14. 转:Yahoo!网站性能最佳体验的34条黄金守则——图片、Coockie与移动应用
  15. python的idel下添加清屏功能
  16. 电大 专科 计算机应用,2015春中央电大计算机应用基础(专科)平时作业(3)
  17. 身份证件识别接口编写的JAVA调用示例
  18. 内蒙古职称计算机考试文件,2017年内蒙古职称计算机考试复习:word2003(三)
  19. 高手视频制作用的是哪些软件?
  20. LaTeX公式保姆级教程

热门文章

  1. 【最新技术早知道】PCIe Gen5 还没用上,Gen6 就来了?PCIe 6.0 系列文章之:《PCIe 6.0,到底 6 在哪?》
  2. 交换机的几种配置方法
  3. 如何删除电脑里的android驱动程序,【教程】安卓手机系统自带程序卸载
  4. 学生信息管理系统——python版(附流程图)
  5. 天津医科大学计算机研究生吧,天津医科大学
  6. java如何编写spi接口_软件模拟SPI接口程序代码(4种模式)
  7. markdown 文本内跳转,生成目录
  8. 数据页和数据行(翻译)
  9. 中文文本纠错算法走到多远了?
  10. [转载]以xilinx为例的低功耗设计