# 农历200年算法(1901~2100)[C语言]

1391人阅读 评论(0)

 6 5 4 3 2 1 0 表示春节的公历月份 表示春节的公历日期

 19 18 17 16 15 14 13 12 11 10 9 8 7 1 2 3 4 5 6 7 8 9 10 11 12 13 农历1-13 月大小 。月份对应位为1，农历月大(30 天),为0 表示小(29 天)

 23 22 21 20 表示当年闰月月份，值为0 为则表示当年无闰月。

#include <time.h>

unsigned int LunarCalendarDay;

unsigned int LunarCalendarTable[199] = {

0x6A4DBE,0x0A4D52,0x0D2546,0x5D52BA,0x0B544E,0x0D6A43,0x296D37,0x095B4B,0x749BC1,0x049754,/*1911-1920*/

0x0AB54F,0x04B645,0x4A5739,0x0A574D,0x052642,0x3E9335,0x0D9549,0x75AABE,0x056A51,0x096D46,/*1961-1970*/

0x04974F,0x064B44,0x36A537,0x0EA54A,0x86B2BF,0x05AC53,0x0AB647,0x5936BC,0x092E50,0x0C9645,/*1991-2000*/

0x09374B,0x8497C1,0x049753,0x064B48,0x66A53C,0x0EA54F,0x06B244,0x4AB638,0x0AAE4C,0x092E42,/*2051-2060*/

0x3C9735,0x0C9649,0x7D4ABD,0x0D4A51,0x0DA545,0x55AABA,0x056A4E,0x0A6D43,0x452EB7,0x052D4B,/*2061-2070*/

0x0D5252,0x0DAA47,0x66B53B,0x056D4F,0x04AE45,0x4A4EB9,0x0A4D4C,0x0D1541,0x2D92B5          /*2091-2099*/

};

int LunarCalendar(int year,int month,int day)

{

int Spring_NY,Sun_NY,StaticDayCount;

int index,flag;

//Spring_NY 记录春节离当年元旦的天数。

//Sun_NY 记录阳历日离当年元旦的天数。

if( ((LunarCalendarTable[year-1901] & 0x0060) >> 5) == 1)

Spring_NY = (LunarCalendarTable[year-1901] & 0x001F) - 1;

else

Spring_NY = (LunarCalendarTable[year-1901] & 0x001F) - 1 + 31;

Sun_NY = MonthAdd[month-1] + day - 1;

if( (!(year % 4)) && (month > 2))

Sun_NY++;

//StaticDayCount记录大小月的天数 29 或30

//index 记录从哪个月开始来计算。

//flag 是用来对闰月的特殊处理。

//判断阳历日在春节前还是春节后

if (Sun_NY >= Spring_NY)//阳历日在春节后（含春节那天）

{

Sun_NY -= Spring_NY;

month = 1;

index = 1;

flag = 0;

if( ( LunarCalendarTable[year - 1901] & (0x80000 >> (index-1)) ) ==0)

StaticDayCount = 29;

else

StaticDayCount = 30;

while(Sun_NY >= StaticDayCount)

{

Sun_NY -= StaticDayCount;

index++;

if(month == ((LunarCalendarTable[year - 1901] & 0xF00000) >> 20) )

{

flag = ~flag;

if(flag == 0)

month++;

}

else

month++;

if( ( LunarCalendarTable[year - 1901] & (0x80000 >> (index-1)) ) ==0)

StaticDayCount=29;

else

StaticDayCount=30;

}

day = Sun_NY + 1;

}

else//阳历日在春节前

{

Spring_NY -= Sun_NY;

year--;

month = 12;

if ( ((LunarCalendarTable[year - 1901] & 0xF00000) >> 20) == 0)

index = 12;

else

index = 13;

flag = 0;

if( ( LunarCalendarTable[year - 1901] & (0x80000 >> (index-1)) ) ==0)

StaticDayCount = 29;

else

StaticDayCount = 30;

while(Spring_NY > StaticDayCount)

{

Spring_NY -= StaticDayCount;

index--;

if(flag == 0)

month--;

if(month == ((LunarCalendarTable[year - 1901] & 0xF00000) >> 20))

flag = ~flag;

if( ( LunarCalendarTable[year - 1901] & (0x80000 >> (index-1)) ) ==0)

StaticDayCount = 29;

else

StaticDayCount = 30;

}

day = StaticDayCount - Spring_NY + 1;

}

LunarCalendarDay |= day;

LunarCalendarDay |= (month << 6);

if(month == ((LunarCalendarTable[year - 1901] & 0xF00000) >> 20))

return 1;

else

return 0;

}

main()

{

const char *ChDay[] = {"*","初一","初二","初三","初四","初五",

"初六","初七","初八","初九","初十",

"十一","十二","十三","十四","十五",

"十六","十七","十八","十九","二十",

"廿一","廿二","廿三","廿四","廿五",

"廿六","廿七","廿八","廿九","三十"};

const char *ChMonth[] = {"*","正","二","三","四","五","六","七","八","九","十","十一","腊"};

struct tm * Local;

long t;

int year,month,day;

char str[13] = "";

#if 0

t = time(NULL);

Local = localtime(&t);

year = Local->tm_year + 1900;

month = Local->tm_mon + 1;

day = Local-> tm_mday;

#else

year = 2006;

month = 9;

day = 9;

#endif

printf("%d年%d月%d日/t",year,month,day);

if(LunarCalendar(year,month,day))

{

strcat(str,"闰");

strcat(str,ChMonth[(LunarCalendarDay & 0x3C0) >> 6]);

}

else

strcat(str,ChMonth[(LunarCalendarDay & 0x3C0) >> 6]);

strcat(str,"月");

strcat(str,ChDay[LunarCalendarDay & 0x3F]);

puts(str);

system("pause");

}

来源
0
0

* 以上用户言论只代表其个人观点，不代表CSDN网站的观点或立场
个人资料
• 访问：154248次
• 积分：1597
• 等级：
• 排名：千里之外
• 原创：25篇
• 转载：10篇
• 译文：7篇
• 评论：39条
阅读排行
评论排行