为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

阴历完整算法

2013-01-12 7页 pdf 57KB 25阅读

用户头像

is_017064

暂无简介

举报
阴历完整算法 面向对象编程五大原则.txt 一、 阳历算法 具体算法见函数Void get_solar_day_date(void),这样阳历日历的星期排法就 确定了。 表1: 月份 1 2 3 4 5 6 7 8 9 10 11 12 闰年 31 29 31 30 31 30 31 31 30 31 30 31 非闰年 31 28 31 30 31 30 31 31 30 31 30 31 变量定义: Public: Unsigned int temp_total_day; Unsigned char gc_...
阴历完整算法
面向对象编程五大原则.txt 一、 阳历算法 具体算法见函数Void get_solar_day_date(void),这样阳历日历的星期排法就 确定了。 1: 月份 1 2 3 4 5 6 7 8 9 10 11 12 闰年 31 29 31 30 31 30 31 31 30 31 30 31 非闰年 31 28 31 30 31 30 31 31 30 31 30 31 变量定义: Public: Unsigned int temp_total_day; Unsigned char gc_solar_calendar_year; Unsigned char gc_solar_calendar_month; Unsigned char gc_solar_calendar_date; Unsigned char gc_lunar_calendar_year; Unsigned char gc_lunar_calendar_month; Unsigned char gc_lunar_calendar_date; Unsigned char start_day_of_week; 说明:函数get_solar_day_date(void)的输入变量:gc_solar_calendar_year 和 gc_solar_calendar_month 输出变量:start_day_of_week和temp_total_day Void get_solar_day_date(void) { unsigned char temp01; /*------calculate what day is the day of the current month and year. Mon~Sun?--- */ /*条件初始化二次,减少运算数据量. temp_total_day 是int型变量*/ start_day_of_week = 2; temp_total_day = 0;calculate_temp = 1; if(gc_solar_calendar_year > 99) {start_day_of_week = 6;calculate_temp = 100;} for(temp01 = calculate_temp; temp01 99) {gc_lunar_calendar_year = 99;gc_lunar_calendar_month = 11; gc_lunar_calendar_date = 25;temp_total_day += 25;calculate_temp = 100;} else {gc_lunar_calendar_year = 0;gc_lunar_calendar_month = 11; 第 3 页 面向对象编程五大原则.txt gc_lunar_calendar_date = 11;temp_total_day += 11;calculate_temp = 1;} if(gc_solar_calendar_year >calculate_temp||gc_solar_calendar_month>1) { for(mc_tpumenus_temp_loop = 1;mc_tpumenus_temp_loop>0;){ temp_total_day -=calendar_calculate_lunar_month_total_day(); temp_leap_month = tpumenus_lunar_calendar_month_table[2*gc_lunar_calendar_year + 1]; temp_leap_month = (temp_leap_month>>4)&0x0F; if(gc_lunar_calendar_month == temp_leap_month) {switch(gc_lunar_calendar_year) {case 6,14,19,25,33,36,38,41,44,52,55,79,117, 136,147,150,155,158,185,193: if(temp_total_day<31){gc_lunar_calendar_date = temp_total_day; mc_tpumenus_temp_loop = 0;temp_flag = 0;} else temp_total_day -= 30; break; //current month:temp_leap_month default: if(temp_total_day < 30) {gc_lunar_calendar_date = temp_total_day;mc_tpumenus_temp_loop = 0; temp_flag = 0; /*current month:temp_leap_month*/ } else temp_total_day -= 29; break;}} if(temp_flag){gc_lunar_calendar_month++; if(gc_lunar_calendar_month == 13){gc_lunar_calendar_month = 1; gc_lunar_calendar_year++;} If(temp_total_day < 61) //if temp_total_day>60,ignore compare {mc_tpumenus_temp_01 = calendar_calculate_lunar_month_total_day(); if(temp_total_day < (mc_tpumenus_temp_01 + 1)) {mc_tpumenus_temp_loop = 0;gc_lunar_calendar_date = temp_total_day; } } } } } gc_lunar_leap_month = (temp_flag<<4)|temp_leap_month;/*set leap_month flag*/ 说明:函数calendar_calculate_lunar_month_total_day(void)根据输入变量 gc_lunar_calendar_year和gc_lunar_calendar_month,结合压缩数据表 lunar_calendar_month_table计算出对应阴历月的总的天数。 unsigned char calendar_calculate_lunar_month_total_day(void) { unsigned char mc_tpumenus_temp_01; unsigned char mc_tpumenus_temp_02; if(gc_lunar_calendar_month < 9) {mc_tpumenus_temp_01 = lunar_calendar_month_table[2*gc_lunar_calendar_year]; mc_tpumenus_temp_02 = gc_lunar_calendar_month - 1;} else{ mc_tpumenus_temp_01 = lunar_calendar_month_table[2*gc_lunar_calendar_year + 1]; mc_tpumenus_temp_02 = gc_lunar_calendar_month - 9;} if((mc_tpumenus_temp_01>> mc_tpumenus_temp_02)&0x01)return(29); 第 4 页 面向对象编程五大原则.txt else return(30);} 阳历日和农历节气的对应关系 压缩节气数据表: 根据规律可以得到四个数据表(每个阳历月有两个节气,每个节气需要两个数 据表): const unsigned char calendar_solar_term_table_01[12][33] = { {7,6,6,6,6,6,6,6,6,5,6,6,6,5,5,6,6,5,5,5,5,5,5,5,5,4,5,5}, //month 1 {5,4,5,5,5,4,4,5,5,4,4,4,4,4,4,4,4,3,4,4,4,3,3,4,4,3,3,3}, //2 {6,6,6,7,6,6,6,6,5,6,6,6,5,5,6,6,5,5,5,6,5,5,5,5,4,5,5,5,5}, //3 {5,5,6,6,5,5,5,6,5,5,5,5,4,5,5,5,4,4,5,5,4,4,4,5,4,4,4,4,5}, //4 {6,6,6,7,6,6,6,6,5,6,6,6,5,5,6,6,5,5,5,6,5,5,5,5,4,5,5,5,5}, //5 {6,6,7,7,6,6,6,7,6,6,6,6,5,6,6,6,5,5,6,6,5,5,5,6,5,5,5,5,4,5,5,5,5}, //6 {7,8,8,8,7,7,8,8,7,7,7,8,7,7,7,7,6,7,7,7,6,6,7,7,6,6,6,7,7}, //7 {8,8,8,9,8,8,8,8,7,8,8,8,7,7,8,8,7,7,7,8,7,7,7,7,6,7,7,7,6,6,7,7,7}, //8 {8,8,8,9,8,8,8,8,7,8,8,8,7,7,8,8,7,7,7,8,7,7,7,7,6,7,7,7,7}, //9 {9,9,9,9,8,9,9,9,8,8,9,9,8,8,8,9,8,8,8,8,7,8,8,8,7,7,8,8,8}, //10 {8,8,8,8,7,8,8,8,7,7,8,8,7,7,7,8,7,7,7,7,6,7,7,7,6,6,7,7,7}, //11 {7,8,8,8,7,7,8,8,7,7,7,8,7,7,7,7,6,7,7,7,6,6,7,7,6,6,6,7,7}, //12 }; //这个数据表表示了每个月第一个节气出现的规律 const unsigned char calendar_solar_term_year_01[12][9] = { {13,49,85,117,149,185,201,250,250}, //month 1 {13,45,81,117,149,185,201,250,250}, //2 {13,48,84,112,148,184,200,201,250}, //3 {13,45,76,108,140,172,200,201,250}, //4 {13,44,72,104,132,168,200,201,250}, //5 {5 ,33,68,96 ,124,152,188,200,201}, //6 {29,57,85,120,148,176,200,201,250}, //7 {13,48,76,104,132,168,196,200,201}, //8 {25,60,88,120,148,184,200,201,250}, //9 {16,44,76,108,144,172,200,201,250}, //10 {28,60,92,124,160,192,200,201,250}, //11 {17,53,85,124,156,188,200,201,250}, //12 }; //这个数据表表示了每个月第一个节气出现规律对应的阳历年份范围 const unsigned char calendar_solar_term_table_02[12][29] = { {21,21,21,21,21,20,21,21,21,20,20,21,21,20,20,20,20,20,20,20,20,19,20 ,20,20,19,1 9,20}, {20,19,19,20,20,19,19,19,19,19,19,19,19,18,19,19,19,18,18,19,19,18,18 ,18,18,18,1 8,18}, {21,21,21,22,21,21,21,21,20,21,21,21,20,20,21,21,20,20,20,21,20,20,20 ,20,19,20,2 0,20,20}, {20,21,21,21,20,20,21,21,20,20,20,21,20,20,20,20,19,20,20,20,19,19,20 第 5 页 面向对象编程五大原则.txt ,20,19,19,1 9,20,20}, {21,22,22,22,21,21,22,22,21,21,21,22,21,21,21,21,20,21,21,21,20,20,21 ,21,20,20,2 0,21,21}, {22,22,22,22,21,22,22,22,21,21,22,22,21,21,21,22,21,21,21,21,20,21,21 ,21,20,20,2 1,21,21}, {23,23,24,24,23,23,23,24,23,23,23,23,22,23,23,23,22,22,23,23,22,22,22 ,23,22,22,2 2,22,23}, {23,24,24,24,23,23,24,24,23,23,23,24,23,23,23,23,22,23,23,23,22,22,23 ,23,22,22,2 2,23,23}, {23,24,24,24,23,23,24,24,23,23,23,24,23,23,23,23,22,23,23,23,22,22,23 ,23,22,22,2 2,23,23}, {24,24,24,24,23,24,24,24,23,23,24,24,23,23,23,24,23,23,23,23,22,23,23 ,23,22,22,2 3,23,23}, {23,23,23,23,22,23,23,23,22,22,23,23,22,22,22,23,22,22,22,22,21,22,22 ,22,21,21,2 2,22,22}, {22,22,23,23,22,22,22,23,22,22,22,22,21,22,22,22,21,21,22,22,21,21,21 ,22,21,21,2 1,21,22}, }; //这个数据表表示了每个月第二个节气出现的规律 const unsigned char calendar_solar_term_year_02[12][8] = { {13,45,81,113,149,185,201},{21,57,93,125,161,193,201}, {21,56,88,120,152,188,200,201}, {21,49,81,116,144,176,200,201},{17,49,77,112,140,168,200,201}, {28,60,88,116,148,180,200,201},{25,53,84,112,144,172,200,201}, {29,57,89,120,148,180,200,201},{17,45,73,108,140,168,200,201}, {28,60,92,124,160,192,200,201},{16,44,80,112,148,180,200,201}, {17,53,88,120,156,188,200,201},}; //这个数据表表示了每个月第二个节气出现规律对应的阳历年份范围 每个阳历月对应的两个农历节气出现的日期,可根据条件规律算法,分别由以 下两个函数实 现: unsigned char calendar_calculate_solar_term_1(void) { zpage unsigned char done_index; zpage unsigned char solar_term; done_index = 0; while(gc_solar_calendar_year >= calendar_solar_term_year_01 [gc_solar_calendar_month - 1][done_index]) {done_index++;} solar_term = calendar_solar_term_table_01[gc_solar_calendar_month - 1] 第 6 页 面向对象编程五大原则.txt [4*done_index + gc_solar_calendar_year%4]; if((gc_solar_calendar_year == 121)&&(gc_solar_calendar_month == 4))solar_term = 5; if((gc_solar_calendar_year == 132)&&(gc_solar_calendar_month == 4))solar_term = 5; if((gc_solar_calendar_year == 194)&&(gc_solar_calendar_month == 6))solar_term = 6; return(solar_term); } //计算阳历月对应的第一个节气 unsigned char calendar_calculate_solar_term_2(void) { zpage unsigned char done_index; zpage unsigned char solar_term; done_index = 0; while(gc_solar_calendar_year >= calendar_solar_term_year_02 [gc_solar_calendar_month - 1][done_index]){done_index++;} solar_term = calendar_solar_term_table_02[gc_solar_calendar_month - 1] [4*done_index + gc_solar_calendar_year%4]; if((gc_solar_calendar_year == 171)&&(gc_solar_calendar_month == 3))solar_term = 21; if((gc_solar_calendar_year == 181)&&(gc_solar_calendar_month == 5))solar_term = 21; return(solar_term); } //计算阳历月对应的第二个节气 以上就是万年历的完整算法。它首先计算出对应阳历月第一天对应是星期几, 然后根据数据 压缩算法确定,确定对应的阴历日期;而阴历节气,则有条件规律算法实现。 第 7 页
/
本文档为【阴历完整算法】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。

历史搜索

    清空历史搜索